OpenCV中cvADDS()为啥第二个参数要是CvScalar类型?mask=NULL又是何意?

欢迎大家加入图像识别技术交流群:271891601,另外,特别欢迎成都从事图像识别工作的朋友交流,我的QQ号2487872782
-----------------------------------------------
void cvAddS(const CvArr* src, CvScalar value, CvArr* dst, const CvArr* mask=NULL)

首先你要明白Scalar是标量的意思,即不是向量的意思,所以第二个参数其实就是给图像矩阵的所有像素加上一个常数值而已!那为什么不直接写个数字呢?而需要是CvScalar类型呢?原因其实很简单,因为图像可能不是灰度图像,也可能不是二值图像,而是RGB图像!RGB一个像素对应三个矩阵,所以你的第二个参数也该是三个标量才行!

具体我们来看下CvScalar在OpenCV中的定义哈!

typedef struct CvScalar
{
    double val[4];
}
CvScalar;

可见,其实就是一个结构体名,其中有一个成员,这个成员是一个大小为4的dobule数组!

关于mask=NULL的含义,可以参看下面这篇文章
http://wenku.baidu.com/link?url=V3m_P5nlvM_mzXL-bjlpZ-vhVhnatxPanOEoTTviAom07S_dx8gLvMSDPYxjV974JogEokE-5ZLaMr7dZiTdFwUEyso5vXV9rmSlRFvbreK

关于mask的理解,我提供下面的关键词和语句哈:

mask其实就是掩码的含义 

mask = NULL  意思就是不使用掩码操作,这里NULL和0的含义应该是不一样的

你可能感兴趣的:(opencv)