opencv获取图像的像素值

来源:互联网 发布:免费网络在线代理 编辑:程序博客网 时间:2024/04/28 13:34

1、matlab获取彩色图像像素值的方法
    img=imread('test.jpg');
    img1=img(:,:,1);
    img2=img(:,:,2);
    img3=img(:,:,3);
    三通道排序分别对应彩色图像的rgb三通道
2、opencv中获取图像像素的方法
方法一:
   IplImage *img = cvLoadImage("Lena.jpg", 0);
   CvScalar pixel;
 for (int i = 0; i < img->height; ++i)
 {
     for (int j = 0; j < img->width; ++j)
      {
         //获得像素的RGB值并显示   
          pixel = cvGet2D(img, i, j);
           printf("B=%f,G=%f,R=%f\t", pixel.val[0], pixel.val[1], pixel.val[2]);
         //修改各点的值
          pixel.val[0] = 0;   // B分量
          pixel.val[1] = 0;   // G分量
          pixel.val[2] = 0;   // R分量
         cvSet2D(img, i, j, pixel);
  }
 }
注意内存中存储顺序是BGR
方法二:
 for (int i = 0; i < img->height; ++i)
 {
        for (int j = 0; j < img->width; ++j)
     {
        int  b = CV_IMAGE_ELEM(paintx, uchar, y1, x1 * 3);
        int  g = CV_IMAGE_ELEM(paintx, uchar, y1, x1 * 3+1);
        int  r= CV_IMAGE_ELEM(paintx, uchar, y1, x1 * 3+2);
      }
}
方法三:

for (int x = 0; x<src1->width; x++){for (int y = 0; y<src1->height; y++){uchar v = ((uchar*)(src1->imageData + src1->widthStep*y))[x];num[v]++;}}



对于单通道字节型图像: IplImage* img=cvCreateImage(cvSize(640,480),IPL_DEPTH_8U,1);  ((uchar *)(img->imageData + i*img->widthStep))[j]=111;对于多通道字节型图像:IplImage* img=cvCreateImage(cvSize(640,480),IPL_DEPTH_8U,3);  ((uchar *)(img->imageData + i*img->widthStep))[j*img->nChannels + 0]=111; // B ((uchar *)(img->imageData + i*img->widthStep))[j*img->nChannels + 1]=112; // G ((uchar *)(img->imageData + i*img->widthStep))[j*img->nChannels + 2]=113; // R对于多通道浮点型图像: IplImage* img=cvCreateImage(cvSize(640,480),IPL_DEPTH_32F,3);  ((float *)(img->imageData + i*img->widthStep))[j*img->nChannels + 0]=111; // B ((float *)(img->imageData + i*img->widthStep))[j*img->nChannels + 1]=112; // G ((float *)(img->imageData + i*img->widthStep))[j*img->nChannels + 2]=113; // R

方法四:

for (j = 0; j < h; j++){uchar* im_data = im->ptr<uchar>(2*j);uchar* imnew_data = imnew.ptr<uchar>(j);for (i = 0; i < w; i++)imnew_data[i] = im_data[i * 2];}

3 ((uchar*)(Img1->imageData + Img1->widthStep*pt.y))[pt.x]的具体含义:
 (1)这里img1->imagedata指的图像第一行的首地址,pt.y是指图像的height(图像高像素数即行数),y乘以img->widthstep(排列的图像行大小)即首地址加上行数乘以每行总数,得到第y行的首地址。widthstep是指图像每行所占的字节数,主要要和width区别,width是指每行所含的像素个数,但是一个像素也可能占一个字节,也可能占三个字节或者四个。imagedata是指向存储图像像素值数组的指针,内容是这个数组的首地址,pt.y指的是像素点的行坐标,所以Img->imageData + Img->widthStep*pt.y便是该像素点所在行的首地址,然后再加上该像素点所在的列,即pt.x,就得到了该像素点的地址,所以那句代码也可以写成
((uchar*)(Img1->imageData + Img1->widthStep*pt.y+pt.x)),
都是指该像素点的像素值,至于强制类型转换,是因为会产生一些负值,而像素值是不能为负的。
(2)widthStep表示存储一行像素需要的字节数。
widthStep必须是4的倍数,如果8U图像宽度为3,那么widthStep是4,加一个字节补齐。这个图像的一行需要4个字节,只使用前3个,最后一个空在那儿不用。也就是一个宽3高3的图像的imageData数据大小为4*3=12字节。如果32F的图像,那么widthStep=width*4。

0 0