#include <iostream>
#include <opencv2/opencv.hpp>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
using namespace std;
using namespace cv;
bool ROI_AddImage();
bool LinearBlending();
bool ROI_LinearBlending();
int main() {
//system("color 6F");
if(ROI_AddImage()&&LinearBlending()&&ROI_LinearBlending())
//if(ROI_AddImage()&&LinearBlending())
cout<<endl<<"运行成功"<<endl;
cv::waitKey(0);
return 0;
}
bool ROI_AddImage(){
Mat srcImage1 = imread("dota_pa.jpg",1);
Mat logoImage = imread("dota_logo.jpg");
cout<<"srcImage :\t"<<srcImage1.rows<<"\t"<<srcImage1.cols<<endl;
cout<<"logoImage :\t"<<logoImage.rows<<"\t"<<logoImage.cols<<endl;
Mat imageROI = srcImage1(Rect(0,0,logoImage.cols,logoImage.rows));
Mat mask = imread("dota_logo.jpg",0);//必须是读入灰度图
logoImage.copyTo(imageROI,mask);
namedWindow("1.ROI实现图像线性混合");
imshow("1.ROI实现图像线性混合",srcImage1);
return true;
}
bool LinearBlending(){
double alphaValue = 0.5;
double betaValue;
Mat srcImage2,srcImage3,dstImage;
srcImage2 = imread("mogu.jpg");
srcImage3 = imread("rain.jpg");
betaValue = 1-alphaValue;
addWeighted(srcImage2,alphaValue,srcImage3,betaValue,0.,dstImage);
namedWindow("2.线性混合");
imshow("2.线性混合",dstImage);
return true;
}
bool ROI_LinearBlending(){
Mat srcImage4 = imread("dota_pa.jpg",1);
Mat logoImage = imread("dota_logo.jpg",1);
// imshow("logoImage",logoImage);
Mat imageROI = srcImage4(Rect(0,0,logoImage.cols,logoImage.rows));
addWeighted(imageROI,0.5,logoImage,0.5,0.,imageROI);//需要保证相加的两个大小相同
cout<<"srcImage"<<srcImage4.rows<<","<<srcImage4.cols<<endl;
cout<<"logoImage"<<logoImage.rows<<","<<logoImage.cols<<endl;
cout<<"imageROI"<<imageROI.rows<<imageROI.cols<<endl;
namedWindow("3.ROI+线性混合");
imshow("3.ROI+线性混合",srcImage4);
return true;
}
注意:
1.cols代表长度,横着的,rows代表宽度,竖着的
2.addWeighted函数需要保证相加的两幅图像是大小(rows和cols)是一样的