OpenCV这么简单为啥不学——1.10、addWeighted设置图片透明度

简介: OpenCV这么简单为啥不学——1.10、addWeighted设置图片透明度

OpenCV这么简单为啥不学——1.10、addWeighted设置图片透明度


前言

计算机视觉市场巨大而且持续增长,且这方面没有标准API,如今的计算机视觉软件大概有以下三种:

1、研究代码(慢,不稳定,独立并与其他库不兼容)

2、耗费很高的商业化工具(比如Halcon, MATLAB+Simulink)

3、依赖硬件的一些特别的解决方案(比如视频监控,制造控制系统,医疗设备)这是如今的现状,而标准的API将简化计算机视觉程序和解决方案的开发,OpenCV致力于成为这样的标准API。

OpenCV致力于真实世界的实时应用,通过优化的C代码的编写对其执行速度带来了可观的提升,并且可以通过购买Intel的IPP高性能多媒体函数库(Integrated Performance Primitives)得到更快的处理速度。

故而我们选择学习OpenCV,我们来一步步的学习OpenCV。


cv2.addWeighted函数

语法:

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

参数:

src1:第一个原数组.

alpha:第一个数组元素权重

src2:第二个原数组

beta:第二个数组元素权重

gamma:图1与图2作和后添加的数值。不要太大,不然图片一片白。总和等于255以上就是纯白色了。

参数6:dst,输出图片

5:5权重测试代码

import cv2
# 想覆盖,两个图片的像素必须相同,否则会报异常
"""
Exception:where arrays have the same size and the same number of channels
"""
img1 = cv2.imread('800_600.jpg')
img2 = cv2.imread('8_600_top_1.jpg')
# 透明度 5 : 5
new_img = cv2.addWeighted(img1, 0.5, img2, 0.5, 0)
cv2.imshow('new_img', new_img)
cv2.waitKey(0)
cv2.destroyAllWindows()

实际效果:

所有权重比例效果测试0.1~0.9

我们遍历一下看看效果:

import cv2
import shutil
import os
# 想覆盖,两个图片的像素必须相同,否则会报异常
"""
Exception:where arrays have the same size and the same number of channels
"""
img1 = cv2.imread('800_600.jpg')
img2 = cv2.imread('8_600_top_1.jpg')
save_dir = "Demo2/"
try:
    # 递归删除文件夹
    shutil.rmtree(save_dir)
    os.makedirs(save_dir)
except OSError:
    pass
for item in range(1, 10):
    index1 = round(item * 0.1, 1)  # 低
    index2 = round(1 - index1, 1)  # 顶
    # 透明度 index : 1-index
    new_img = cv2.addWeighted(img1, index1, img2, index2, 0)
    cv2.imwrite('{0}type_value_{1}_{2}.jpg'.format(save_dir, index1, index2), new_img)
    # 透明度 1-index : index
    new_img = cv2.addWeighted(img1, index2, img2, index1, 0)
    cv2.imwrite('{0}type_value_{1}_{2}.jpg'.format(save_dir, index2, index1), new_img)

我们可以看到整个的效果展示:

相关文章
|
21天前
|
计算机视觉
Opencv学习笔记(十二):图片腐蚀和膨胀操作
这篇文章介绍了图像腐蚀和膨胀的原理、作用以及使用OpenCV实现这些操作的代码示例,并深入解析了开运算和闭运算的概念及其在图像形态学处理中的应用。
76 1
Opencv学习笔记(十二):图片腐蚀和膨胀操作
|
23天前
|
计算机视觉 Python
Opencv学习笔记(二):如何将整个文件下的彩色图片全部转换为灰度图
使用OpenCV库将一个文件夹内的所有彩色图片批量转换为灰度图,并提供了相应的Python代码示例。
31 0
Opencv学习笔记(二):如何将整个文件下的彩色图片全部转换为灰度图
|
23天前
|
计算机视觉 Python
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
这篇博客介绍了如何使用OpenCV库在Python中将图片保存到指定目录,以及如何将文件夹中的所有图片读取并以数组形式输出。
107 0
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
|
6月前
|
监控 API 计算机视觉
OpenCV这么简单为啥不学——1.13图片冷白皮(美白)处理
OpenCV这么简单为啥不学——1.13图片冷白皮(美白)处理
68 0
|
23天前
|
计算机视觉
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
在使用OpenCV的cv2模块保存带有中文命名的图片时,直接使用cv2.imwrite()会导致乱码问题,可以通过改用cv2.imencode()方法来解决。
99 0
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
|
3月前
|
计算机视觉 Windows Python
windows下使用python + opencv读取含有中文路径的图片 和 把图片数据保存到含有中文的路径下
在Windows系统中,直接使用`cv2.imread()`和`cv2.imwrite()`处理含中文路径的图像文件时会遇到问题。读取时会返回空数据,保存时则无法正确保存至目标目录。为解决这些问题,可以使用`cv2.imdecode()`结合`np.fromfile()`来读取图像,并使用`cv2.imencode()`结合`tofile()`方法来保存图像至含中文的路径。这种方法有效避免了路径编码问题,确保图像处理流程顺畅进行。
263 1
|
3月前
|
计算机视觉 索引
OpenCv实时设置摄像头参数/获得摄像头参数值的方法论
这篇文章提供了一个OpenCV的实例教程,展示了如何使用`createTrackbar()`函数实时设置和获取摄像头参数值,如饱和度、Gamma和亮度,并通过回调函数在程序中连续修改这些参数。
|
21天前
|
Serverless 计算机视觉
语义分割笔记(三):通过opencv对mask图片来画分割对象的外接椭圆
这篇文章介绍了如何使用OpenCV库通过mask图像绘制分割对象的外接椭圆。首先,需要加载mask图像,然后使用`cv2.findContours()`寻找轮廓,接着用`cv2.fitEllipse()`拟合外接椭圆,最后用`cv2.ellipse()`绘制椭圆。文章提供了详细的代码示例,展示了从读取图像到显示结果的完整过程。
39 0
语义分割笔记(三):通过opencv对mask图片来画分割对象的外接椭圆
|
3月前
|
存储 编解码 API
python多种方法压缩图片,opencv、PIL、tinypng、pngquant压缩图片
python多种方法压缩图片,opencv、PIL、tinypng、pngquant压缩图片
208 1
|
3月前
|
计算机视觉
使用QT显示OpenCV读取的图片
使用QT显示OpenCV读取的图片
59 1