Opencv笔记(八)——图像上的算数运算
学习目标:
学习图像上的算术运算,加法,减法,位运算等。
- 学习函数cv2.add(),cv2.addWeighted() 等。
一、图像的加法
你可以使用函数 cv2.add() 将两幅图像进行加法运算,当然也可以直接使用 numpy,res=img1+img。两幅图像的大小,类型必须一致,或者第二个图像可以是一个简单的标量值。注意:OpenCV 中的加法与 Numpy 的加法是有所不同的。OpenCV 的加法是一种饱和操作,而 Numpy 的加法是一种模操作。
x = np.uint8([250])
y = np.uint8([10])
print cv2.add(x,y) # 250+10 = 260 => 255
[[255]]
print x+y
[4]
# 250+10 = 260 % 256 = 4
即对于opencv来说,当像素值大于255时,他会饱和,使值取最大。对于numpy来说,当像素值大于255时,他会取模,令当前像素值取模255。故OpenCV 的结果会更好一点,所以我们尽量使用 OpenCV 中的函数。
import numpy as np
import cv2
img = cv2.imread('/home/wl/ng.png')
img1 = cv2.imread('/home/wl/le.jpeg')
res = cv2.resize(img,(600,500),interpolation=cv2.INTER_CUBIC)
res1 = cv2.resize(img1,(600,500),interpolation=cv2.INTER_CUBIC)
dst = cv2.add(res,res1)
cv2.imshow('opencv',dst)
cv2.imwrite('/home/wl/1.jpg',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
二、图像的混合
这其实也是加法,但是不同的是两幅图像的权重不同,这就会给人一种混合或者透明的感觉。通过修改 α 的值(0 → 1),可以实现非常酷的混合。图像混合的计算公式如下:
g (x) = (1 − α) f 0 (x) + αf 1 (x)
import numpy as np
import cv2
img = cv2.imread('/home/wl/ng.png')
img1 = cv2.imread('/home/wl/le.jpeg')
res = cv2.resize(img,(600,500),interpolation=cv2.INTER_CUBIC)
res1 = cv2.resize(img1,(600,500),interpolation=cv2.INTER_CUBIC)
dst = cv2.addWeighted(res,0.7,res1,0.3,0)
cv2.imshow('opencv',dst)
cv2.imwrite('/home/wl/1.jpg',dst)
cv2.waitKey(0)
cv2.destroyAllWindows()
- cv2.addWeighted()有五个参数,第一个和第二个参数分别是第一副图及其混合比例,第三个和第四个参数分别是第二副图及其混合比例,第五个参数取常数0。
三、结合上一篇博客实现下面要求
创建一个幻灯片用来演示一幅图如何平滑的转换成另一幅图
import numpy as np
import cv2
def nothing(x):
pass
img = np.zeros((600,500),np.uint8)
cv2.namedWindow('image')
cv2.createTrackbar('weight','image',0,100,nothing)
img0 = cv2.imread('/home/wl/ng.png')
img1 = cv2.imread('/home/wl/le.jpeg')
res = cv2.resize(img0,(600,500),interpolation=cv2.INTER_CUBIC)
res1 = cv2.resize(img1,(600,500),interpolation=cv2.INTER_CUBIC)
while(1):
cv2.imshow('image', img)
k = cv2.waitKey(1) & 0xFF
if k == ord('q'):
break
r = cv2.getTrackbarPos('weight', 'image')
r = float(r)/100.0
img = cv2.addWeighted(res,r,res1,1-r,0)
cv2.imwrite('/home/wl/1.jpg',img)
cv2.destroyAllWindows()
对于图像的按位运算,我将在后面博客介绍。
Opencv笔记(八)——图像上的算数运算的更多相关文章
- SpringMVC学习笔记八:文件上传及多个文件上传
SpringMVC实现文件上传需要加入jar包,commons-fileupload-1.3.1.jar,commons-io-2.2.jar 项目目录树: pom.xml加入需要的包 <pro ...
- OpenCV学习笔记(4)——图像上的算术运算
学习图像上的算术运算,加法,减法,位运算等 1.图像加法 使用cv2.add()将两幅图像进行加法运算,也可以用numpy运算,直接img+img1.两幅图像的大小和类型必须一致,或者第二个图像可以是 ...
- opencv笔记4:模板运算和常见滤波操作
time:2015年10月04日 星期日 00时00分27秒 # opencv笔记4:模板运算和常见滤波操作 这一篇主要是学习模板运算,了解各种模板运算的运算过程和分类,理论方面主要参考<图像工 ...
- 【opencv学习笔记八】创建TrackBar轨迹条
createTrackbar这个函数我们以后会经常用到,它创建一个可以调整数值的轨迹条,并将轨迹条附加到指定的窗口上,使用起来很方便.首先大家要记住,它往往会和一个回调函数配合起来使用.先看下他的函数 ...
- Python下opencv使用笔记(图像频域滤波与傅里叶变换)
Python下opencv使用笔记(图像频域滤波与傅里叶变换) 转载一只程序喵 最后发布于2018-04-06 19:07:26 阅读数 1654 收藏 展开 本文转载自 https://blog ...
- opencv笔记2:图像ROI
time:2015年 10月 03日 星期六 12:03:45 CST # opencv笔记2:图像ROI ROI ROI意思是Region Of Interests,感兴趣区域,是一个图中的一个子区 ...
- Opencv笔记(二):图像的基本操作——续写
1.图像的透视变换 对于视角变换,我们需要一个 3x3 变换矩阵.在变换前后直线还是直线.要构建这个变换矩阵,你需要在输入图像上找 4 个点,以及他们在输出图像上对应的位置.这四个点中的任意三个都不能 ...
- OpenCV之响应鼠标(四):在图像上绘制出矩形并标出起点的坐标
涉及到两方面的内容:1. 用鼠标画出矩形.2.在图像上绘制出点的坐标 用鼠标绘制矩形,涉及到鼠标的操作,opencv中有鼠标事件的介绍.需要用到两个函数:回调函数CvMouseCallback和注册回 ...
- OpenCV学习笔记(7)——图像阈值
简单阈值,自适应阈值,Otsu's二值化等 1.简单阈值 当像素值高于阈值时,我们给这个像素赋予一个新值,否则给他赋予另一个值.这个函数就是cv2.threshhold().这个函数的第一个参数就是原 ...
随机推荐
- java多线程并发(一)-- 相关基础知识
java多线程的知识是java程序员都应该掌握的技能,目前我接触的项目上用的不多,花点时间熟悉熟悉. 一.基础知识 1.什么是进程? 进程是具有一定独立功能的正在运行过程中的程序,是操作系统进行资源分 ...
- UVALive 3977 BFS染色
这个题意搞了半天才搞明白 就是如果定义一个d-summit,即从该点到另一个更高的点,经过的路径必定是比当前点低至少d高度的,如果该点是最高点,没有比他更高的,就直接视为顶点 其实就是个BFS染色,先 ...
- <style scoped >中使用深度选择器影响子组件
摘自:https://blog.csdn.net/zhouzuoluo/article/details/95593143 <style scoped >中使用深度选择器影响子组件 在< ...
- idea~创建maven webapp项目
1.选择 org.apache.maven.archtypes:maven-archtype-webapp 2.禁止远程下载 archetypeCatalog=internal 目的是不远程下载,否则 ...
- ✨vue引入组件 axios和icont矢量图标
axios 在vue项目开发中,我们使用axios进行ajax请求,很多人一开始使用axios的方式,会当成vue-resoure的使用方式来用,即在主入口文件引入import VueResource ...
- Socket通讯的简单用法
1.客户端 package Thread; import java.io.BufferedReader; import java.io.IOException; import java.io.Inpu ...
- 18 12 23 html 基本学习
一个html的基本结构如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...
- github访问过慢解决
为了更加愉快地使用全球最大同性交友网站上的优质资源,我们来做一些简单的本机上的调整. 通过查看下载链接,能够发现最终被指向到Amazon的服务器(http://github-cloud.s3.amaz ...
- js获取指定日期n天之后的日期
function addDays(date, days,seperator='-') { let oDate = new Date(date).valueOf(); let nDate = oDate ...
- UML-测试驱动开发
1.什么是测试驱动开发? 测试驱动开发(TDD)是迭代和敏捷XP方法提倡的优秀实践,该实践为测试测试优先开发.不仅包含单元测试. 2.为什么测试驱动开发? 1).最大提升代码稳定性 2).澄清接口和行 ...