1. 使用ROI进行图像融合
1.1 定义ROI
方法一: 用矩形区域Rect,指定矩形框的左上角点和宽高。
Mat ImgROI = src(Rect(20, 20, logo.cols, logo.rows));
方法二: 用范围(Range)建立索引。
Mat ImgROI = src(Range(20,20+logo.rows),Range(20,20+logo.cols));
1.2 将掩膜Mask复制到ROI
通过掩膜将插入处的像素设为logo的像素值。
1.3 完整代码
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/opencv.hpp>
using namespace cv;
int main()
{
//读取图像并展示
Mat src = imread("D:\\desk\\james.jpg");
Mat logo = imread("D:\\desk\\logo.jpg");
if (!src.data)
{
printf("src读取错误");
return false;
}
if (!logo.data)
{
printf("logo读取错误");
return false;
}
Mat ImgROI = src(Rect(20, 20, logo.cols, logo.rows));
Mat Mask = imread("D:\\desk\\logo.jpg");
logo.copyTo(ImgROI, Mask);
namedWindow("融合结果");
imshow("融合结果",src);
waitKey(0);
return 0;
}
2. 使用加权函数进行图像融合
2.1 加权函数原型:
void addWeighted(InputArray Src1, double alpha, InputArray Src2, double beta, double gamma, OutputArray dst, int type = -1)
参数解释:
InputArray Src1:需要加权的第一个数组
alpha:第一个数组的权重
InputArray Src2:需要加权的第二个数组,它需要和第一个数组具有相同的尺寸和通道数
beta:第二个数组的权重
gamma: 加到权重总和上的标量
OutputArray dst:输出的数组,它需要和两数组具有相同的尺寸和通道数
type:输出阵列的可选深度,默认为-1.
计算公式:
dst = Src1 * alpha + Src2 * beta + gamma;
2.2 完整代码
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/opencv.hpp>
using namespace cv;
int main()
{
//读取图像并展示
Mat src = imread("D:\\desk\\james.jpg");
Mat logo = imread("D:\\desk\\logo.jpg");
if (!src.data)
{
printf("src读取错误");
return false;
}
if (!logo.data)
{
printf("logo读取错误");
return false;
}
Mat ImgROI = src(Rect(20, 20, logo.cols, logo.rows));
addWeighted(ImgROI, 0, logo, 1, 0, ImgROI);
namedWindow("融合结果");
imshow("融合结果",src);
waitKey(0);
return 0;
}