opencv从零开始——2. ROI与线性融合

1.感兴趣的区域:ROI

ROI : 感兴趣的区域(region  of  interest )
代码如下:
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <iostream>

using namespace cv;
using namespace std;

bool ROI_AddImage()
{
    Mat srcImage1 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg");
    Mat logoImage = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg");

    if (!srcImage1.data) {
        return false;
    }

    if (!logoImage.data) {
        return false;
    }

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

    Mat mask = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg", 0);

    logoImage.copyTo(imageROI, mask);

    namedWindow("<1>利用ROI实现图像叠加示例窗口");
    imshow("<1>利用ROI实现图像叠加示例窗口", srcImage1);
    Mat img = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg");
    imshow("原图", img);
    waitKey(0);
    return true;

}

//"/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/v1.jpg"
int main(int argc, char* argv[])
{
    ROI_AddImage();

    return 0;
}


效果如下,小猫吃鱼的图片,就是插入进去的:



2. 图像融合

【注意】需要两幅图像,尺寸一致,本次采用的尺寸: 550*405

代码如下:
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <iostream>

using namespace cv;
using namespace std;

bool ROI_AddImage()
{
    Mat srcImage1 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg");
    Mat logoImage = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg");

    if (!srcImage1.data) {
        return false;
    }

    if (!logoImage.data) {
        return false;
    }

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

    Mat mask = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg", 0);

    logoImage.copyTo(imageROI, mask);

    namedWindow("<1>利用ROI实现图像叠加示例窗口");
    imshow("<1>利用ROI实现图像叠加示例窗口", srcImage1);
    Mat img = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg");
    imshow("原图", img);
    waitKey(0);
    return true;

}

bool LinearBlending()
{
    double alphaValue = 0.5;
    double betaValue;

    Mat srcImage2, srcImage3, dstImage;
    //两幅图片,需要裁剪成相同的尺寸,本例采用尺寸: 550 * 405
    srcImage2 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/kobe.jpg");
    srcImage3 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/James.jpg");

    if (!srcImage2.data || !srcImage3.data) {
        return false;
    }

    betaValue = 1.0 - alphaValue;
    addWeighted(srcImage2, alphaValue, srcImage3, betaValue, 0.0, dstImage);

    namedWindow("<3>线性混合示例窗口[效果图]", 1);
    imshow("<3>线性混合示例窗口[效果图]", dstImage);

    waitKey(0);
    return true;
}

//"/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/v1.jpg"
int main(int argc, char* argv[])
{
    //ROI_AddImage();
    LinearBlending();
    return 0;
}

原图如下:



效果图如下:



3. 对感兴趣的区域,融入一幅图像

代码如下:
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <iostream>

using namespace cv;
using namespace std;

bool ROI_AddImage()
{
    Mat srcImage1 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg");
    Mat logoImage = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg");

    if (!srcImage1.data) {
        return false;
    }

    if (!logoImage.data) {
        return false;
    }

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

    Mat mask = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg", 0);

    logoImage.copyTo(imageROI, mask);

    namedWindow("<1>利用ROI实现图像叠加示例窗口");
    imshow("<1>利用ROI实现图像叠加示例窗口", srcImage1);
    Mat img = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg");
    imshow("原图", img);
    waitKey(0);
    return true;

}

bool LinearBlending()
{
    double alphaValue = 0.5;
    double betaValue;

    Mat srcImage2, srcImage3, dstImage;
    //两幅图片,需要裁剪成相同的尺寸,本例采用尺寸: 550 * 405
    srcImage2 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/kobe.jpg");
    srcImage3 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/James.jpg");

    if (!srcImage2.data || !srcImage3.data) {
        return false;
    }

    betaValue = 1.0 - alphaValue;
    addWeighted(srcImage2, alphaValue, srcImage3, betaValue, 0.0, dstImage);

    namedWindow("<3>线性混合示例窗口[效果图]", 1);
    imshow("<3>线性混合示例窗口[效果图]", dstImage);

    waitKey(0);
    return true;
}

void ROI_AddImage_LinearBlending()
{
    Mat srcImage1 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg", 1);
    Mat logoImage = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo.jpg");

    if (!srcImage1.data) {
        return;
    }

    if (!logoImage.data) {
        return;
    }

    Mat imageROI = srcImage1(Rect(20, 230, logoImage.cols, logoImage.rows));
    addWeighted(imageROI, 0.5, logoImage, 0.3, 0. , imageROI);

    namedWindow("<4>利用ROI实现图像叠加示例窗口");
    imshow("<4>利用ROI实现图像叠加示例窗口", srcImage1);
    Mat img = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg");
    imshow("原图", img);
    waitKey(0);
}

//"/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/v1.jpg"
int main(int argc, char* argv[])
{
    //ROI_AddImage();
    //LinearBlending();
    ROI_AddImage_LinearBlending();
    return 0;
}

效果图:





4.参考文献

[1] 毛星云 冷雪飞. OpenCV3编程入门[M]. 电子工业出版社, 2015.
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值