OpenCV学习笔记:像素级访问的两种方法

前言
当使用OpenCV对图像进行处理时,了解如何独立地访问每个像素是十分必要的。本文会介绍两种方法:第一种方法对程序员来说较为简单,而第二种方法在某种特定情况下效率会更高。

1.模板函数at<>

实例:

//第一种情况
Mat src1 = imread("lena.jpg",IMREAD_GRAYSCALE);
unchar pixel1 = src1.at<uchar>(0,0);
cout << "Value of pixel (0,0):" << (unsigned int)pixel1 << endl;//
//第二种情况
Mat src2 = imread(lena.jpg",IMREAD_COLOR)
Vec3b pixel2 = src2.at<Vec3b>(0,0);
cout << "B component of pixel (0,0):" << (unsigned int)pixel2[0] <<endl;

讲解:
上述例子使用灰度和彩色两种方式读取同一幅图像,并访问图像的第一个像素。
在第一种情况中,图像以灰度方式读取,像素类型是无符号字符(即uchar);
在第二种情况下,图像以全色方式读取,必须使用Vect3b类型,它指向一个无符号字符的三元组。

注意:使用模板函数at<>必须指定矩阵单元的类型。

除此之外,模板函数还可以出现在赋值符号的左侧,即改变一个像素的值。实例如下:

Mat M(200,200,CV_64F);
for(int i = 0;i < M.rows;i++)
   for(int j = 0;j < M.cols;j++)
      M.at<double>(i,j) = CV_PI;   //将浮点矩阵初始化为Pi值

2.函数ptr

实例:

uchar R,G,B;
for(int i = 0;i<src2.rows;i++)
{
   Vec3b* pixrow = src2.ptr<Vec3b>(i);  //函数ptr的返回值是指向图像特定行的一个指针。
   for(int j = 0;j < src2.cols;j++)
   {
     B = pixrow[j][0];
     G = pixrow[j][1];
     R = pixrow[j][2];
    }
}

讲解:
上述例子获取一幅彩色图像中每个像素的像素值。
其中,ptr用来得到一个指向每行在第一个像素的指针,然后使用这个指针可以在内层循环中实现访问每一列。

你可能感兴趣的:(OpenCV学习笔记)