OpenCV图像融合的两种方法

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 
#include 
#include 
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 
#include 
#include 
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;
}

你可能感兴趣的:(OpenCV专栏,opencv,计算机视觉,人工智能)