【OpenCV】分离多通道图像RGB的值

《访问图像中每个像素的值》中我们介绍了存储图像的结构体IplImage的数据结构。多通道字节/浮点型图像中存储了每个像素RGB三信道的值。

最近在做的项目中需要提取图像ROI区域RGB的平均值,发现有一个cvAvg函数:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. CvScalar cvAvg( const CvArr* arr, const CvArr* mask=NULL );  
可以独立计算数组每个通道的平均值,非常方便。所以用如下方式即可达到效果:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. CvScalar avgChannels = cvAvg(img);    
  2. double avgB=avgChannels.val[0];  
  3. double avgG=avgChannels.val[1];  
  4. double avgR=avgChannels.val[2];  
那如果我们想分离出每个通道的具体值,可以用cvSlip(或cvCvtPixToPlane)函数:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. void cvSplit( const CvArr* src, CvArr* dst0, CvArr* dst1,  
  2.                CvArr* dst2, CvArr* dst3 );  
  3. #define cvCvtPixToPlane cvSplit  
如果再想把分离的图像显示出来,可以分别create三个单通道的图像,即:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. IplImage* rImg=cvCreateImage(cvGetSize(img),IPL_DEPTH_8U,1);    
  2. IplImage* gImg=cvCreateImage(cvGetSize(img),IPL_DEPTH_8U,1);    
  3. IplImage* bImg=cvCreateImage(cvGetSize(img),IPL_DEPTH_8U,1);    

此时的效果是这样的,三个灰色图像:


但我其实想做个演示效果,就是要那种看出分离的是“红”“绿”“蓝”的效果。

于是尝试用cvCvtColor将单通道图转换为多通道图:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. void cvCvtColor( const CvArr* src, CvArr* dst, int code );    
  2. // src为单通道图像,dst为多通道图像,code设置为CV_GRAY2BGR  
结果还是一样的……

那就手动用cvMerge()自己重新Merge一个多通道图吧:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. IplImage* rImg3=cvCreateImage(cvGetSize(pImg),IPL_DEPTH_8U,3);    
  2. IplImage* gImg3=cvCreateImage(cvGetSize(pImg),IPL_DEPTH_8U,3);    
  3. IplImage* bImg3=cvCreateImage(cvGetSize(pImg),IPL_DEPTH_8U,3);   
  4. cvMerge(0,0,rImg,0,rImg3);  
  5. cvMerge(0,gImg,0,0,gImg3);  
  6. cvMerge(bImg,0,0,0,bImg3);  
结果还是一样的……

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. cvMerge(rImg,rImg,rImg,0,rImg3);  
还是原来的效果!!!这次我真囧了……(其实后来想起C#里没有灰度图的类型,显示灰度图就是靠这种方式:把RGB的值设置成相同的)

最后尝试如下方式:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. cvMerge(bImg,gImg,0,0,rImg3);  
  2. cvMerge(bImg,0,rImg,0,gImg3);  
  3. cvMerge(0,gImg,rImg,0,bImg3);  
才终于达到了想要的效果:


哈哈~


(转载请注明作者和出处:http://blog.csdn.net/xiaowei_cqu 未经允许请勿用于商业用途)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值