前言常用

1.在OpenCV中定义了好多函数用来操作图像矩阵,有两个矩阵相加的,相减的,混合的,下面我使用QT加OpenCV演示图像融合这个函数。
2.我的IDE是Qt creator,OpenCV的版本是3.30,系统环境是Linux。

矩阵操作

1.图像融合
OpenCV图像融合所用的函数是addWeighted()。
函数原型:

void addWeighted(InputArray src1, double alpha, InputArray src2, double beta, double gamma, OutputArray dst, int dtype=-1);

参数说明:
第一个参数:src1,表示进行加权操作的第一个图像对象,即输入图片1;
第二个参数:double型的alpha,表示第一个图像的加权系数,即图片1的融合比例;
第三个参数:src2,表示进行加权操作的第二个图像对象,即输入图片2;
第四个参数:double型的beta,表示第二个图像的加权系数,即图片2的融合比例。很多情况下,有关系 alpha+beta=1.0;
第五个参数:double型的gamma,表示一个作用到加权和后的图像上的标量,可以理解为加权和后的图像的偏移量;
第六个参数:dst,表示两个图像加权和后的图像,尺寸和图像类型与src1和src2相同,即输出图像;
第七个参数:输出阵列的可选深度,有默认值-1。当两个输入数组具有相同的深度时,这个参数设置为-1(默认值),即等同于src1.depth()。
(1)图像融合有两种方式,第一种是全部融合,要求输入图像大小是一样的。

void addImage(Mat &one_cv_img,Mat& two_cv_img, Mat &dst)
{if(one_cv_img.empty() && two_cv_img.empty()){cout << "请先打开图像!" << endl;}if(one_cv_img.size() != two_cv_img.size()){cv::resize(one_cv_img, one_cv_img, Size(two_cv_img.cols, two_cv_img.rows));}addWeighted(two_cv_img, 0.3, one_cv_img, 0.7, 0, dst);
}

输入的两张图像大小不一,按第二张来缩放第一张图像。
输入的图像:


输出的结果:

(2)第二是感兴趣(ROI)区域融会。

void addImageRoi(Mat &one_cv_img,Mat& two_cv_img, Mat &dst)
{if(one_cv_img.empty() && two_cv_img.empty()){ cout << "请先打开图像!" << endl;return;}//判断大小if ((one_cv_img.cols < two_cv_img.cols) || (one_cv_img.rows < two_cv_img.rows)){cout<<"ROI区域大于原图"<<endl;return;}dst = one_cv_img.clone();Mat image_roi;//在dst上选定一个与要融合图像大小一样的区域image_roi = dst(Rect(100, 100, two_cv_img.cols, two_cv_img.rows));//将选定区域imageROI和logoImage按0.3:0.7混合,结果存放到选定区域ImageROIaddWeighted(image_roi, 0.3, two_cv_img, 0.7, 0.0, image_roi);imshow("roi",dst);
}

第一张输入的图像,下面可以看到图像尺寸,注意,第一张图像一定要比第二张图像大。

第二张输入的图像:

输出结果图像:

OpenCV图像处理使用笔记(四)——图像融合相关推荐

  1. OpenCV图像处理使用笔记(六)——图像滤波

    前言 1.图像滤波也叫图像模糊,是平滑图像像素常用处理的方式,通常是为了达到减少图像噪声和伪影,或者降低图像分辨率,OpenCV提供了常用的五种图像模糊操作. 2.我的这里演示的系统环境是Linux, ...

  2. OpenCV图像处理使用笔记(五)——图像边界拓展

    前言 1.在OpenCV滤波和卷积算法中,在进行核运算的过程时候,矩阵边界拓展是一个非常重要的处理,OpenCV提供的函数copyMakeBorder()来拓展边界. 2.我的系统环境是Linux,加 ...

  3. [Python从零到壹] 三十七.图像处理基础篇之图像融合处理和ROI区域绘制

    欢迎大家来到"Python从零到壹",在这里我将分享约200篇Python系列文章,带大家一起去学习和玩耍,看看Python这个有趣的世界.所有文章都将结合案例.代码和作者的经验讲 ...

  4. OpenCV图像处理(7)——图像上写TEXT

    在图像上写字 /* 参数说明: 1.输入输出图像 2.需要写的字符 3.文字的左上角坐标 4.字体 5.标准字体的放大倍数(越大,字体越大) 6... 7... */ putText(copySrc, ...

  5. Python+OpenCV图像处理(五)——图像阈值和二值化

    系列文章 Python+OpenCV图像处理(一)--OpenCV框架与图像插值算法 Python+OpenCV图像处理(二)--几何变换 Python+OpenCV图像处理(三)--彩色空间互换 P ...

  6. HI3559算法移植之OpenCV图像拼接、配准和图像融合技术(三)

    图像拼接比较经典的是SIFT.SURF.ORB等算法.其中SURF是SIFT的升级版,在实时性上要优于后者.本次先实现图片级的融合.拼接. SURF的构建流程是:构建Hessian矩阵.H矩阵判别式. ...

  7. 《OpenCv视觉之眼》Python图像处理十六:Opencv图像处理实战一之图像中的硬币检测

    本专栏主要介绍如果通过OpenCv-Python进行图像处理,通过原理理解OpenCv-Python的函数处理原型,在具体情况中,针对不同的图像进行不同等级的.不同方法的处理,以达到对图像进行去噪.锐 ...

  8. [Python图像处理] 二十四.图像特效处理之毛玻璃、浮雕和油漆特效

    该系列文章是讲解Python OpenCV图像处理知识,前期主要讲解图像入门.OpenCV基础用法,中期讲解图像处理的各种算法,包括图像锐化算子.图像增强技术.图像分割等,后期结合深度学习研究图像识别 ...

  9. OpenCV图像处理(14)—— 图像转视频

    引言 有个项目,需要将osg生成的批量图像转成视频:特点是,图像自带编号,类似于: Ir_Scene_339.jpg 的格式. 操作中,使用OpenCV自带的video函数完成. void Image ...

最新文章

  1. [译] 通过视图控制器容器和子视图控制器避免庞大的视图控制器
  2. php+mysqli实现批量执行插入、更新及删除数据的方法
  3. 深度学习在CTR预估的应用
  4. window 2003 linux,一步步从Windows 2003 DNS 移植到Linux下
  5. 搜索引擎的十大秘密(收藏)
  6. freemarker 对null 的处理
  7. Python快速使用jira模块调用Jira接口
  8. trunk vlan 加路由
  9. SVN工作笔记006---解决TortoiseSVN中out of date问题的一个方法
  10. 最受欢迎 Top 12 Python 开源框架,你都用过吗?| 原力计划
  11. Freemarker判断对象是否为空的用法
  12. deepin系统15.6版本安装执行那个exe文件_深度操作系统 deepin 20(1003)正式版发布:计算器支持科学计算,新增邮件、相机等应用...
  13. idea运行maven:No URLs will be polled as dynamic configuration sources
  14. 第2章-计算机组成原理之概述篇
  15. 【Python】所有常用Python库和功能查询表
  16. 微前端框架 之 qiankun
  17. cadence SPB17.4 - orcad - exprot sch PDF
  18. 使用Fiddler抓公众号数据
  19. PS CC2019安装
  20. 【CSDN问答】使用体验、产品BUG和改进建议

热门文章

  1. 图片转svg标注_两个免费网站轻松搞定图片文件压缩转化!
  2. 两个排序数组合并第k或前k个最小值问题
  3. CEDD(Color and Edge Directivity Descriptor)学习篇
  4. MFC显示JPG、JIF图片
  5. 一个面试官对JVM面试问题的分析
  6. intellij idea使用的准备工作
  7. 发一张你认为很漂亮的美女照片?
  8. Learning to Rank简介
  9. Markdown 简明教程
  10. Ubuntu安装wps Linux版