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().这个函数的第一个参数就是原 ...
随机推荐
- SpringBoot 系列教程之事务不生效的几种 case
SpringBoot 系列教程之事务不生效的几种 case 前面几篇博文介绍了声明式事务@Transactional的使用姿势,只知道正确的使用姿势可能还不够,还得知道什么场景下不生效,避免采坑.本文 ...
- javascript 连续赋值(连等运算)问题研究
前几天看到一个javascript 连续赋值的问题,运行了一下,结果出乎意料,发现这里的水真的有点深啊,连续赋值的底层机制,没有一本前端书籍有详细介绍的,自己做实验研究了一下,先来看结果: var a ...
- 吴裕雄--天生自然 PHP开发学习:echo 和 print 语句
<?php echo "<h2>PHP 很有趣!</h2>"; echo "Hello world!<br>"; ec ...
- springboot~不用模板执行html文件
放到在resources/static目录下,创建目录或html文件,均可.如:
- Spring框架之一 读取配置文件
以下代码都是来源于官方源码(Spring-4.3.18.RELEASE),此处只是为自己以后深啃先布局出大概流程,请各看官不要浪费时间看 说明: .. 表示省略代码, // 后的如果不是源码自带则为当 ...
- 201771010123汪慧和《面向对象程序设计Java》第十三周实验总结
一.理论部分 1.GUI为用户提供交互式的图形化操作界面. (1)提供了程序的外观和感觉.(2)程序利用图形用户界面接受用户的输入,向用户输出程序运行的结果. 2.Java有专门的类库生成各种标准图 ...
- Sequence Models Week 3 Trigger word detection
Trigger Word Detection Welcome to the final programming assignment of this specialization! In this w ...
- dp--区间dp P1880 [NOI1995]石子合并
题目描述 在一个圆形操场的四周摆放 N 堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分. 试设计出一个算法,计算出将 N 堆石子 ...
- {转}Java 字符串分割三种方法
http://www.chenwg.com/java/java-%E5%AD%97%E7%AC%A6%E4%B8%B2%E5%88%86%E5%89%B2%E4%B8%89%E7%A7%8D%E6%9 ...
- python交互图
花了时间, 记录一下 # -*- coding:utf-8 -*- import matplotlib.pyplot as plt from matplotlib.patches import Rec ...