1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
| int main(int argc, char *argv[])
{
IplImage* img = 0;
short nbl,nbc,step,channels;
unsigned char *data;
int i,j,k;
char name[40] = { '\0' };
printf("Nom du fichier image : ");
fgets(name,39,stdin);
* strchr(name,'\n') = '\0';
img=cvLoadImage(name,1);
if(!img){
printf("Could not load image file: %s\n",argv[1]);
exit(0);
}
nbl = img->height;
nbc = img->width;
step = img->widthStep;
channels= img->nChannels;
data = (uchar *)img->imageData;
printf("Image de taille %dx%d avec %d cannal\n",nbl,nbc,channels);
for(i=0;i<nbl;i++) for(j=0;j<nbc;j++) for(k=0;k<channels;k++)
{
SIM[i][j]=255-data[i*step+j*channels+k];
}
IplImage* dest=cvCreateImage( cvSize(nbl,nbc), IPL_DEPTH_8U, 1);
for(i=0;i<nbl;i++) for(j=0;j<nbc;j++)
{
{
CvScalar s=cvGet2D(dest,i,j);
s.val[0]=SIM[i][j];
cvSet2D(dest,i,j,s);
}
}
cvReleaseImage(&img );
cvReleaseImage(&dest );
} |
Partager