OpenCV ROI and 加权叠加图像

#include"OpenCVLib2.hpp"
using namespace cv;

int main(){

    Mat srcImage1 = imread("p1.jpg");
    Mat logoImage = imread("t3.jpg");

    if(!srcImage1.data){
        println("读取srcImage1错误~!");
        return -1;
    }
    if(!logoImage.data){
        println("读取logoImage错误~!");
        return -1;
    }
    
    Mat imageROI/*Region of Interest*/ = srcImage1(Rect(200,250,logoImage.cols,logoImage.rows));

    logoImage.copyTo(imageROI);

    namedWindow("利用ROI实现图像叠加实例窗口1");
    imshow("利用ROI实现图像叠加实例窗口1",srcImage1);

    //读取的图片是灰色的
    Mat mask = imread("t3.jpg",0);

    imshow("TEST",mask);

    logoImage.copyTo(imageROI,mask);
    imshow("利用ROI实现图像叠加实例窗口2",srcImage1);

    waitKey(0);

    return 0;

}







#include"OpenCVLib2.hpp"
using namespace cv;

int main(){

    /**
     * Math Formula :
     *  g(x) = (1-a)*f1(x) + a*f2(x) + gama
     * 
     * Formula: 
     * dst = src1[I]*alpha + src2[I]*beta + gama;
     * 每个通道都需要独立的处理.
     */ 
    double alphaValue = 0.5;
    double betaValue;
    Mat src1Img,src2Img,dstImg;
    src1Img = imread("t2.jpg");
    src2Img = imread("t3.jpg");

    if(!src1Img.data){

        println("读取src1Img错误~!");
        return -1;
    }
    if(!src2Img.data){

        println("读取src2Img错误~!");
        return -1;
    }
    betaValue = 1.0 - alphaValue;
    //src1Img 和 src3Img 必须具有相同大小,否则即使编译通过,运行时也会报错!
    addWeighted(src1Img,alphaValue,src2Img,betaValue,0,dstImg);

    imshow("线性混合实例窗口[原图]",src1Img);
    imshow("线性混合实例窗口[效果图]",dstImg);

    waitKey(0);

    return 0;
}








评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值