[Opencv初探之四]:图像Mask叠加和ROI选取
1.ROI区域选取
方法一:使用cv:Rect.顾名思义,cv::Rect表示一个矩形区域。指定矩形的左上角坐标(构造函数的前两个参数)和矩形的长宽(构造函数的后两个参数)就可以定义一个矩形区域。
imageROI=image(Rect(500,250,logo.cols,logo.rows));
方法二:指定感兴趣行或列的范围(Range)。Range是指从起始索引到终止索引(不包括终止索引)的一连段连续序列。cv::Range可以用来定义Range。如果使用cv::Range来定义ROI,那么前例中定义ROI的代码可以重写为:
imageROI=srcImage3(Range(250,250+logoImage.rows),Range(200,200+logoImage.cols));
完整代码:
#include<iostream>
#include<opencv2/opencv.hpp>
using namespace std;
using namespace cv;
int main()
{
Mat srcImage1= imread("../test.jpg");
Mat logoImage= imread("../logo.jpg");
if(!srcImage1.data ) { printf("fail to read srcImage1~! \n"); return false; }
if(!logoImage.data ) { printf("fail to read logoImage! \n"); return false; }
//【2】定义一个Mat类型并给其设定ROI区域
Mat imageROI= srcImage1(Rect(800,700,logoImage.cols,logoImage.rows));
//【3】加载掩模(必须是灰度图)
Mat mask= imread("../logo.jpg",0);
//【4】将掩膜拷贝到ROI
logoImage.copyTo(imageROI,mask);
//【5】显示结果
namedWindow("ROI");
imshow("ROI",srcImage1);
imwrite("addroi.jpg",srcImage1);
waitKey();
return true;
}
效果如下:
2.图像混合叠加,addWeighted()
void addWeighted(InputArray src1, double alpha, InputArray src2, double beta, double gamma, OutputArray dst, int dtype=-1);
参数列表如下:
- InputArray类型的src1,表示需要加权的第一个数组,常常填一个Mat。
- alpha,表示第一个数组的权重
- src2,表示第二个数组,它需要和第一个数组拥有相同的尺寸和通道数。
- beta,表示第二个数组的权重值。
- dst,输出的数组,它和输入的两个数组拥有相同的尺寸和通道数。
- gamma,一个加到权重总和上的标量值。看下面的式子自然会理解。
- dtype,输出阵列的可选深度,有默认值-1。;当两个输入数组具有相同的深度时,这个参数设置为-1(默认值),即等同于src1.depth()。
完整代码如下:
#include<iostream>
#include<opencv2/opencv.hpp>
using namespace std;
using namespace cv;
int main()
{
double alphaValue = 0.5;
double betaValue;
Mat srcImage3, dstImage;
//【1】读取图像,缩放保持相同尺寸
Mat srcImage1= imread("../test.jpg");
Mat srcImage2= imread("../test2.jpg");
resize(srcImage1,srcImage3,Size(1920,1080),0, 0, CV_INTER_LINEAR);
//【2】做图像混合加权操作
betaValue= ( 1.0 - alphaValue );
addWeighted(srcImage2, alphaValue, srcImage3, betaValue, 0.0, dstImage);
//【3】创建并显示原图窗口
namedWindow("add", 1);
imshow("add", dstImage );
imwrite("add.jpg",dstImage);
waitKey();
return 0;
}
效果如下: