#include<opencv2/opencv.hpp>
#include<iostream>
#include<vector>
using namespace std;
using namespace cv;
int main()
{
Mat srcImage = imread("【原图】.jpg");
Mat logo = imread("logo.jpg", 0);
Mat imageROI;
vector<Mat> v;
split(srcImage, v);
imageROI = v[0](Rect(0, 0, logo.cols, logo.rows));
addWeighted(imageROI, 0.0, logo, 1.0, 0.0, imageROI);
/*logo.copyTo(imageROI);*/
merge(v, srcImage);
imshow("【原图+logo蓝色通道】", srcImage);
//将中间变量的像素置零
imageROI = Scalar::all(0);
imageROI = v[1](Rect(0, 0, logo.cols, logo.rows));
addWeighted(imageROI, 0.0, logo, 1.0, 0.0, imageROI);
/*logo.copyTo(imageROI);*/
merge(v, srcImage);
imshow("【原图+logo绿色通道】", srcImage);
//将中间变量的像素置零
imageROI = Scalar::all(0);
imageROI = v[2](Rect(0, 0, logo.cols, logo.rows));
addWeighted(imageROI, 0.0, logo, 1.0, 0.0, imageROI);
/*logo.copyTo(imageROI);*/
merge(v, srcImage);
imshow("【原图+logo红色通道】", srcImage);
waitKey(0);
return 0;
}
Opencv多通道图像混合
最新推荐文章于 2023-09-10 14:44:31 发布