如何合并HSV频道

时间:2013-09-21 18:06:15

标签: c++ opencv

我尝试创建一个程序,可以操纵图像的HSV值,并在操作HSV值之前将完整的HSV图像显示为默认值。我使用Visual C ++ 2008.这是从3个通道显示HSV图像的算法: 1.加载图像 2.将RGB文件转换为HSV 3.将HSV文件拆分为3个通道 4.合并频道 5.显示合并的频道

这是我不完整的源代码(我不能告诉你我的完整,因为它太长了):

...
...
cv::Mat Citra,CitraConv,CitraHSV[3],CitraD,Citra6,CitraH,CitraH1,CitraS,CitraS1,
CitraV,CitraV1;
std::vector<cv::Mat>CitraHSV2(3);
cv::cvtColor(Citra,CitraConv,CV_BGR2HSV);
cv::split(CitraConv,CitraHSV);
CitraH=CitraHSV[0];
CitraH1=CitraH;
CitraS=CitraHSV[1];
CitraS1=CitraS;
CitraV=CitraHSV[2];
CitraV1=CitraV;
CitraHSV2[0]=CitraH1;
CitraHSV2[1]=CitraS1;
CitraHSV2[2]=CitraV1;
cv::merge(CitraHSV2,CitraD);//Error Here
Citra6=CitraD; 
pictureBoxCitra2->Image=IplImageToBitmap(&(IplImage)Citra6);

但是,当我执行程序时,我收到错误“类型'System.Runtime.InteropServices.SEHException'的未处理异常”。错误是从cv :: merge函数中出现的。谁能帮我?这个程序有什么问题?因为当我构建解决方案(F7)程序时没有语法错误。

1 个答案:

答案 0 :(得分:1)

在GitHub上查看我的博客文章和源代码,从网络摄像头处理图像流,这完全符合您的要求。

它是用Scala编写的,但您可以轻松地过滤出所需的信息,例如拆分频道,合并它们等等。将它移植到C ++应该是没有道理的。

Color Extractor