Python OpenCV 之图像的叠加,图像处理取经之旅第 16 天

举报
梦想橡皮擦 发表于 2021/05/26 15:06:04 2021/05/26
2.4k+ 0 0
【摘要】 今天的学习的内容是:通过 Python OpenCV 对图像实现叠加操作,本文只涉及一个函数,即cv2.addWeighted。 cv2.addWeighted 该函数的完整表述为:Python-OpenCV 图像叠加 or 图像混合加权实现。 函数原型如下: dst = cv2.addWeighted(src1, alpha, src2, beta, gamm...

今天的学习的内容是:通过 Python OpenCV 对图像实现叠加操作,本文只涉及一个函数,即cv2.addWeighted

cv2.addWeighted

该函数的完整表述为:Python-OpenCV 图像叠加 or 图像混合加权实现。

函数原型如下:

dst = cv2.addWeighted(src1, alpha, src2, beta, gamma[, dst[, dtype]])

  
 

参数说明(哈哈,这是官方的,点击打开官方说明):

  • src1 – first input array.
  • alpha – weight of the first array elements.
  • src2 – second input array of the same size and channel number as src1.
  • beta – weight of the second array elements.
  • dst – output 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 output array; when both input arrays have the same depth, dtype can be set to -1, which will be equivalent to src1.depth().

参数翻译如下:

  • src1, src2:需要融合叠加的两副图像,要求大小和通道数相等
  • alpha:src1 的权重
  • beta:src2 的权重
  • gamma:gamma 修正系数,不需要修正设置为 0
  • dst:可选参数,输出结果保存的变量,默认值为 None
  • dtype:可选参数,输出图像数组的深度,即图像单个像素值的位数(如 RGB 用三个字节表示,则为 24 位),选默认值 None 表示与源图像保持一致。

返回值:融合叠加的结果图像

官方手册也给出了最终的结果:

dst = src1 × alpha + src2 × beta + gamma;

上面的式子理解为,结果图像 = 图像 1× 系数 1+图像 2× 系数 2+亮度调节量

测试代码如下:

import cv2 as cv

src1 = cv.imread("./123.jpg")
src2 = cv.imread("./456.png")

c = cv.addWeighted(src1, 0.4, src2, 0.6, 0)

cv.imshow("addWeighted", c)

cv.waitKey(0)

  
 

运行之后叠加出的效果图如下:
Python OpenCV 之图像的叠加,图像处理取经之旅第 16 天
如果两个图片的尺寸不同,可以手动调整,也可以通过 resize 进行调整。

  img2 = cv2.resize(img, (w,h), interpolation=cv2.INTER_AREA)

  
 

在检索资料的时候发现了另一个好玩的函数,即 createTrackbar,可以创建一个滚动条,我们也同时学习一下吧。

cv2.createTrackbar

该函数的作用是在 opencv 使用滑动条,函数原型如下:

cv2.createTrackbar(trackbarName, windowName, value, count, onChange)

  
 

参数说明:

  • trackbarName:滑动条的名字;
  • windowName:滑动条被放置的窗口的名字;
  • value:滑动条默认值;
  • count:滑动条的调节的范围(0~count);
  • onChange:调节滑动条时调用的回调函数名。

与此对应的还有一个获取滑动条值的函数,原型是:

value = cv2.getTrackbarPos(trackbarName, windowName)

  
 

参数说明:

  • trackbarName:滑动条的名字;
  • windowName:滑动条被放置窗口的名字。

返回值:滑动条的数值

测试代码如下(拖动滑动条,实现图片的渐变):

import cv2 as cv
import numpy as np
src1 = cv.imread("./123.jpg")
src2 = cv.imread("./456.png")

# 滚动条拖动
def on_change(x): pass

# 创建一个黑色背景的窗口,大小任意,后面会被修改
img = np.zeros((100, 100, 3), np.uint8)
cv.namedWindow("img")

cv.createTrackbar("a", "img", 0, 100, on_change)

while(1): cv.imshow("img", img) # 按键盘上的 esc 退出。 k = cv.waitKey(1) & 0xFF if k == 27: break # 获取滑动条的值 r = cv.getTrackbarPos('a', "img") # 设置系数 print(r) r = float(r)/100.0 # 默认情况下 src1 完全展示,逐步过渡到 src2 img = cv.addWeighted(src1, r, src2, 1.0-r, 0)

cv.destroyAllWindows()

  
 

运行效果如下图所示。
Python OpenCV 之图像的叠加,图像处理取经之旅第 16 天
还找到了一个渐变效果,不需要拖动滑动条也可以实现图片切换。

import cv2
import numpy as np

step_list = [float(0.02 * x) for x in range(0, 51)]
print(step_list)
img1 = cv2.imread("./123.jpg")
img2 = cv2.imread("./456.png")
cv2.imshow("show", img1)
for i in step_list: res = cv2.addWeighted(img1, i, img2, (1-i), 0) cv2.imshow("show", res) cv2.waitKey(60)
if cv2.waitKey(0) == 27: cv2.destroyAllWindows()

  
 

运行结果自行找两张相同大小的图片进行尝试吧。

OpenCV 尾声

1 个小时又过去了,对 Python OpenCV 相关的知识点,你掌握了吗?

空闲之余,可以订阅橡皮擦的爬虫百例课程学习爬虫知识。

想学 Python 爬虫,可以订阅橡皮擦专栏哦~ 🈲🈲🈲🈲 点击发现惊喜 🈲🈲🈲🈲


今天是持续写作的第 55 / 100 天。
如果你有想要交流的想法、技术,欢迎在评论区留言。


如果你想跟博主建立亲密关系,可以关注同名公众号 梦想橡皮擦,近距离接触一个逗趣的互联网高级网虫。
博主 ID:梦想橡皮擦,希望大家点赞评论收藏

文章来源: dream.blog.csdn.net,作者:梦想橡皮擦,版权归原作者所有,如需转载,请联系作者。

原文链接:dream.blog.csdn.net/article/details/112589832

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。