【OpenCV(C++)】ROI区域图像叠加 & 图像混合
感兴趣区域:ROI
在图像处理领域,常常需要设置感兴趣区域(region of interest)来专注或者简化工作过程。即从图像中圈定一个区域,以便进行进一步处理。使用ROI指定想读入的目标,可以减少处理时间,增加精度。
定义ROI区域的方法:
- Rect
指定矩形的左上角坐标和矩形的长宽以定义一个矩形区域。 - Range
从起始索引到终止索引的一连段连续序列。cRange可以用来定义Range。
线性混合操作
线性混合操作是一种典型的二元(两个输入)的像素操作,它的理论公式如下:
通过在范围0到1之间改变α的值,来对两幅图像产生时间上的画面重叠效果。实现方面,主要用了OpenCV中的addWeighted()函数。
计算数组加权和:addWeighted()函数
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <iostream>
using namespace cv;
using namespace std;
int main()
{
Mat srcImage = imread("1.jpg", 1);
Mat logoImage = imread("pigh.jpg");
if (!srcImage4.data) { printf("读取srcImage错误~! \n"); return false; }
if (!logoImage.data) { printf("读取logoImage错误~! \n"); return false; }
Mat imageROI;
//方法一
imageROI = srcImage(Rect(40, 50, logoImage.cols, logoImage.rows));
//方法二
//imageROI= srcImage(Range(250,250+logoImage.rows),Range(200,200+logoImage.cols));
addWeighted(imageROI, 0.5, logoImage, 0.3, 0., imageROI);
imshow("区域线性图像混合示例窗口", srcImage);
waitKey(0);
return 0;
}
运行效果如下: