天天看点

opencv Mat 多通道拆分Split和组合Merge

  1. #include<opencv2/opencv.hpp>  
  2. #include<iostream>  
  3. #include<cassert>  
  4. #include<vector>  
  5. using namespace cv;  
  6. using namespace std;  
  7. int main()  
  8. {  
  9.     Mat srcImage=imread("e:/huangshan.jpg");  
  10.     Mat imageBlue,imageGreen,imageRed;  
  11.     Mat mergeImage;  
  12.     //定义一个Mat向量容器保存拆分后的数据  
  13.     vector<Mat> channels;  
  14.     //判断文件加载是否正确  
  15.     assert(srcImage.data!=NULL);  
  16.     namedWindow("image",CV_WINDOW_AUTOSIZE);  
  17.     namedWindow("mergeImage",CV_WINDOW_AUTOSIZE);  
  18.     //通道的拆分  
  19.     split(srcImage,channels);  
  20.     //提取蓝色通道的数据  
  21.     imageBlue = channels.at(0);  
  22.     //提取绿色通道的数据  
  23.     imageGreen = channels.at(1);  
  24.     //提取红色通道的数据  
  25.     imageRed = channels.at(2);  
  26.     imshow("image",imageBlue);  
  27.     //对拆分的通道数据合并  
  28.     merge(channels,mergeImage);  
  29.     imshow("mergeImage",mergeImage);  
  30.     waitKey();  
  31.     system("pause");  
  32.     return 0;  
  33. }  
  1. #include<opencv2/opencv.hpp>  
  2. #include<iostream>  
  3. #include<cassert>  
  4. #include<vector>  
  5. using namespace cv;  
  6. using namespace std;  
  7. int main()  
  8. {  
  9.     Mat srcImage=imread("e:/jiansheng.jpg");  
  10.     Mat logoImage = imread("e:/timu.jpg",0);  
  11.     Mat imageBlue,imageGreen,imageRed;  
  12.     Mat mergeImage;  
  13.     //定义一个Mat向量容器保存拆分后的数据  
  14.     vector<Mat> channels;  
  15.     //判断文件加载是否正确  
  16.     assert(srcImage.data!=NULL && logoImage.data!=NULL);  
  17.     //namedWindow("image",CV_WINDOW_AUTOSIZE);  
  18.     namedWindow("mergeImage",CV_WINDOW_AUTOSIZE);  
  19.     //通道的拆分  
  20.     split(srcImage,channels);  
  21.     //提取蓝色通道的数据  
  22.     imageBlue = channels.at(1);  
  23.     addWeighted(imageBlue(Rect(0,0,logoImage.cols,logoImage.rows)),0.5,logoImage,0.5,0.,imageBlue(Rect(0,0,logoImage.cols,logoImage.rows)));  
  24.     //对拆分的通道数据合并  
  25.     merge(channels,mergeImage);  
  26.     imshow("mergeImage",mergeImage);  
  27.     waitKey();  
  28.     system("pause");  
  29.     return 0;  
  30. }  
  31. 原文地址:http://blog.csdn.net/omuyejingfeng1/article/details/25685141
  32. sift,surf匹配代码http://blog.csdn.net/omuyejingfeng1/article/details/24372815

继续阅读