#include "stdafx.h"
#include <opencv.hpp>
using namespace cv;
int _tmain(int argc, _TCHAR* argv[])
{
Mat srcImage;
srcImage = imread("yacht.bmp",IMREAD_UNCHANGED);
if (!srcImage.data)
{
printf("Load Image Failed.\n");
return -1;
}
vector<Mat> channels;
//将三通道图像转换为3个单通道图像
split(srcImage,//待颜色通道分割图像
channels //分割后输出的vector容器
);
Mat imageROI1,imageROI2;
imageROI1 = channels.at(0);
imageROI2 = channels.at(1);
Mat dst;
dst.create(Size(200,200),CV_8UC3);
//取两个通道进行融合
addWeighted(imageROI1(Rect(100,200,200,200)),0.3,imageROI2(Rect(100,200,200,200)),0.7,10,dst);
namedWindow("测试窗口");
imshow("测试窗口",dst);
/* 相反过程[合并]
Mat dst2;
dst.create(srcImage.size(),srcImage.type());
merge(channels,dst2);
namedWindow("测试窗口");
imshow("测试窗口",dst2);
*/
waitKey(0);
return 0;
}
原图:
操作之后图: