OpenCV学习:实现简单的图像叠加
本实例使用简单的线性叠加方法来实现两幅图像的叠加,主要使用的知识如下:
1)线性融合
   
2)addWeighted函数
//! computes weighted sum of two arrays (dst = alpha*src1 + beta*src2 + gamma)
CV_EXPORTS_W void addWeighted(InputArray src1,
double alpha,
InputArray src2,
double beta,
double gamma,
OutputArray dst,
int dtype=-1
);
Parameters
src1 – First source array.
alpha – Weight for the first array elements.
src2 – Second source array of the same size and channel number as src1 .
beta – Weight for the second array elements.
dst – Destination array that has the same size and number of channels as the input arrays.
gamma – Scalar added to each sum.
dtype – Optional depth of the destination array. When both input arrays have the same depth, dtype can be set to -1, which will be equivalent to src1.depth().
代码如下:
//图像叠加(Mat)
#include <opencv2/opencv.hpp>
using namespace cv;
using namespace std; int main( int argc, char** argv )
{
double alpha = 0.5;
double beta;
double input;
Mat src1, src2, dst;
/// 请输入alpha值
cout<<" Simple Linear Blender "<<endl;
cout<<"-----------------------"<<endl;
cout<<"*Enter alpha [0-1]: "; /// 获取alpha输入
cin >> input;
if( input >= 0.0 && input <= 1.0 )
{
alpha = input;
}
/// 加载相同尺寸,相同格式的两张图像
src1 = imread("./Res/Windows7_logo.jpg");
src2 = imread("./Res/Windows7_text.jpg");
if( !src1.data )
{
printf("Error loading src1 \n");
return -;
}
if( !src2.data )
{
printf("Error loading src2 \n");
return -;
} /// 创建显示窗口
namedWindow("Image one", );
namedWindow("Image two", );
namedWindow("Linear Blend", ); /// 执行线性融合
beta = 1.0 - alpha;
addWeighted( src1, alpha, src2, beta, 0.0, dst); /// 显示结果
imshow( "Image one", src1 );
imshow( "Image two", src2 );
imshow( "Linear Blend", dst ); /// 等待键盘事件
waitKey();
return ;
}
运行结果:
  
  
OpenCV学习:实现简单的图像叠加的更多相关文章
- 【opencv学习笔记六】图像的ROI区域选择与复制
		图像的数据量还是比较大的,对整张图片进行处理会影响我们的处理效率,因此常常只对图像中我们需要的部分进行处理,也就是感兴趣区域ROI.今天我们来看一下如何设置图像的感兴趣区域ROI.以及对ROI区域图像 ... 
- 学习 opencv---(3) ROI 区域图像叠加&初级图像混合
		在这篇文章里,我们一起学习了在OpenCV中如何定义感兴趣区域ROI,如何使用addWeighted函数进行图像混合操作,以及将ROI和addWeighted函数结合起来使用,对指定区域进行图像混合操 ... 
- 第十三节,OPenCV学习(二)图像的简单几何变换
		图像的简单几何变换 几何变换不改变图像的像素值,只是在图像平面上进行像素的重新安排 适当的几何变换可以最大程度地消除由于成像角度.透视关系乃至镜头自身原因所造成的几何失真所产生的的负面影响. 一.图像 ... 
- 第十四节,OpenCV学习(三)图像的阈值分割
		图像的阈值处理 图像的阈值分割:图像的二值化(Binarization) 阈值分割法的特点是:适用于目标与背景灰度有较强对比的情况,重要的是背景或物体的灰度比较单一,而且总可以得到封闭且连通区域的边界 ... 
- 【OpenCV学习笔记之一】图像加载,修改及保存
		加载图像(用cv::imread)imread功能是加载图像文件成为一个Mat对象 其中第一个参数表示图像文件名称第二个参数 表示加载的图像是什么类型 支持常见的三个参数值IMREAD_UNCHANG ... 
- 第十二节,OpenCV学习(一)图像的读取、显示、保存
		一.读取图像 所谓的图像就是一个数组,对图像的处理就是对数字的处理 import cv2 import numpy as np img = cv2.imread('dog.jpg') print(im ... 
- 【opencv学习笔记五】一个简单程序:图像读取与显示
		今天我们来学习一个最简单的程序,即从文件读取图像并且创建窗口显示该图像. 目录 [imread]图像读取 [namedWindow]创建window窗口 [imshow]图像显示 [imwrite]图 ... 
- OpenCV计算机视觉学习(2)——图像算术运算 & 掩膜mask操作(数值计算,图像融合,边界填充)
		在OpenCV中我们经常会遇到一个名字:Mask(掩膜).很多函数都使用到它,那么这个Mask到底是什么呢,下面我们从图像基本运算开始,一步一步学习掩膜. 1,图像算术运算 图像的算术运算有很多种,比 ... 
- Opencv 图像叠加 添加水印
		Opencv 图像叠加 添加水印 C++: void Mat::copyTo(OutputArray m) const C++: void Mat::copyTo(OutputArray m, Inp ... 
随机推荐
- uva--242(邮资问题  dp)
			输入输出: id=26127" style="color:blue; text-decoration:none">Sample Input 5 2 4 1 4 12 ... 
- centos7 編譯 chmsee
			安装libchm及相关的devel包,安装 xulrunner 及 devel 包!否则后面make的时候会出错! 到解压出来的chmsee/src目录下,找到与你系统对应的Makefile文件,我选 ... 
- Qt 的QString类的使用
			Qt的QString类提供了很方便的对字符串操作的接口. 使某个字符填满字符串,也就是说字符串里的所有字符都有等长度的ch来代替. QString::fill ( QChar ch, int size ... 
- appium安卓自动化常见问题处理
			appium安卓自动化常见问题处理 1.seesionnotcreatedexception 遇到这个首先确定下jdk需要1.7以上 然后还要确定appium是启动状态,可以cmd重启下appium ... 
- Windows Server 2012部署第一台域控
			windows server 2012在部署DC方面有了一些改变,不但在操作上有一些改变,而且有了新的DC克隆的功能.本文就先来体验一下如何将一台windows server 2012 RTM服务器提 ... 
- Android开发日记(四)
			在服务器端数据库新建一个表ad 在DataInfo.edxm模型中点击从数据库更新模型,发布. 就新建了一个实体ad 然后新建cs文件 using System; using System.Colle ... 
- Python 进行 SSH 操作,实现本地与服务器的链接,进行文件的上传和下载
			Python 进行 SSH 操作,实现本地与服务器的链接,进行文件的上传和下载 2018年5月26日 19:03 阅读 375 评论 7 我本地和服务器的连接一直使用的是 Xshell 5,而在与服务 ... 
- sql插入数据
			using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ... 
- 一款纯css3实现的机器人看书动画效果
			今天要给大家介绍一款纯css3实现的机器人看书动画效果.整个画面完全由css3实现的绘制,没有使用任何图片元素.机器人的眼睛使用了动画元素.我们一起看下效果图: 在线预览 源码下载 实现的代码. ... 
- Unity Vector3.Slerp使用范例
			using System.Collections; using System.Collections.Generic; using UnityEngine; public class TestSler ... 
