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

Original: https://blog.csdn.net/m0_48609675/article/details/123451082
Author: 啊哒啊哒啊
Title: OpenCV图像融合的两种方法

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/703036/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球