OpenCV初级图像混合ROI+linear

#include <iostream>
#include <opencv2/opencv.hpp>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
using namespace std;
using namespace cv;

bool ROI_AddImage();
bool LinearBlending();
bool ROI_LinearBlending();


int main() {
    //system("color 6F");

    if(ROI_AddImage()&&LinearBlending()&&ROI_LinearBlending())
    //if(ROI_AddImage()&&LinearBlending())
        cout<<endl<<"运行成功"<<endl;
    cv::waitKey(0);


    return 0;
}

bool ROI_AddImage(){
    Mat srcImage1 = imread("dota_pa.jpg",1);
    Mat logoImage = imread("dota_logo.jpg");
    cout<<"srcImage :\t"<<srcImage1.rows<<"\t"<<srcImage1.cols<<endl;
    cout<<"logoImage :\t"<<logoImage.rows<<"\t"<<logoImage.cols<<endl;

    Mat imageROI = srcImage1(Rect(0,0,logoImage.cols,logoImage.rows));

    Mat mask = imread("dota_logo.jpg",0);//必须是读入灰度图

    logoImage.copyTo(imageROI,mask);
    namedWindow("1.ROI实现图像线性混合");
    imshow("1.ROI实现图像线性混合",srcImage1);
    return true;
}

bool LinearBlending(){
    double alphaValue = 0.5;
    double betaValue;
    Mat srcImage2,srcImage3,dstImage;

    srcImage2 = imread("mogu.jpg");
    srcImage3 = imread("rain.jpg");

    betaValue = 1-alphaValue;
    addWeighted(srcImage2,alphaValue,srcImage3,betaValue,0.,dstImage);
    namedWindow("2.线性混合");
    imshow("2.线性混合",dstImage);

    return true;
}

bool ROI_LinearBlending(){
    Mat srcImage4 = imread("dota_pa.jpg",1);
    Mat logoImage = imread("dota_logo.jpg",1);
//    imshow("logoImage",logoImage);


    Mat imageROI = srcImage4(Rect(0,0,logoImage.cols,logoImage.rows));
    addWeighted(imageROI,0.5,logoImage,0.5,0.,imageROI);//需要保证相加的两个大小相同

    cout<<"srcImage"<<srcImage4.rows<<","<<srcImage4.cols<<endl;
    cout<<"logoImage"<<logoImage.rows<<","<<logoImage.cols<<endl;
    cout<<"imageROI"<<imageROI.rows<<imageROI.cols<<endl;

    namedWindow("3.ROI+线性混合");
    imshow("3.ROI+线性混合",srcImage4);

    return true;

}

注意:

1.cols代表长度,横着的,rows代表宽度,竖着的

2.addWeighted函数需要保证相加的两幅图像是大小(rows和cols)是一样的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Tech沉思录

点赞加投币,感谢您的资瓷~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值