废话不多说,上代码
#include<opencv2/opencv.hpp>
#include<iostream>
using namespace std;
using namespace cv;
bool ROI_AddImage();//ROI区域图像叠加函数
bool LinearBlending();//初级图像混合函数
bool ROI_LinearBlending();//ROI区域图像混合加权函数
int main()
{
system("color 5E");//改变控制窗颜色
if (ROI_AddImage() && LinearBlending() && ROI_LinearBlending()) {
cout << "operation success!" << endl;
}
waitKey(0);
return 0;
}
bool ROI_AddImage()
{
//读取图像
Mat img1 = imread("C:/Users/xihua/Desktop/aixin.png");
Mat img2 = imread("C:/Users/xihua/Desktop/xinhaicheng.png");
if (!img1.data) {
cout << "No imge!" << endl; return false;
}
if (!img2.data) {
cout << "No imge!" << endl; return false;
}
//设定ROI区域
Mat ROIimg = img2(Rect(100, 100, img1.cols, img1.rows));
Mat mask = imread("C:/Users/xihua/Desktop/aixin.png",0);//掩膜操作(图像必须设为灰色)
img1.copyTo(ROIimg, mask);//把掩膜拷贝到ROI区域
namedWindow("ROI区域掩膜操作");
imshow("ROI区域掩膜操作", img2);
return true;
}
bool LinearBlending()
{
double alphaValue = 0.5;//第一个加权值
double betaValue = 1.0 - alphaValue;//第二个加权值
Mat img1 = imread("C:/Users/xihua/Desktop/meigui.jpg");
Mat img2 = imread("C:/Users/xihua/Desktop/yushui.jpg");
if (!img1.data) {
cout << "No imge!" << endl; return false;
}
if (!img2.data) {
cout << "No imge!" << endl; return false;
}
Mat img3;
//进行图像混合加权操作
addWeighted(img2, alphaValue, img1, betaValue, 0.0, img3);//
namedWindow("初级图像混合操作");
imshow("初级图像混合操作", img3);
return true;
}
bool ROI_LinearBlending()
{
Mat img1 = imread("C:/Users/xihua/Desktop/aixin.png");
Mat img2 = imread("C:/Users/xihua/Desktop/xinhaicheng.png");
if (!img1.data) {
cout << "No imge!" << endl; return false;
}
if (!img2.data) {
cout << "No imge!" << endl; return false;
}
Mat ROI_img = img2(Rect(100, 100, img1.cols, img1.rows));//设定ROI区域
//进行ROI区域的图像混合加权操作
addWeighted(ROI_img, 0.5, img1, 0.3, 0.0, ROI_img);
namedWindow("ROI区域图像叠加操作");
imshow("ROI区域图像叠加操作", img2);
return true;
}
一定要注意图片大小,进行图像混合加权操作时,两个图片尺寸要相同,否则会出现冲突行为报错,ROI区域掩膜操作和ROI区域图像混合加权操作时,掩膜的图像的尺寸一定要保证能放进另一个图片中,否则也会出现冲突报错。我一开始没注意到,后来我就debug了一个多小时〒▽〒
具体详细内容请见