OpenCV合并图片cv2.add、无缝连接图片cv2.addWeighted、图片克隆cv2.seamlessClone 效果对比、按位运算bitwise_and

👨‍💻个人简介: 深度学习图像领域工作者
🎉总结链接:
             链接中主要是个人工作的总结,每个链接都是一些常用demo,代码直接复制运行即可。包括:
                    📌1.工作中常用深度学习脚本
                    📌2.torch、numpy等常用函数详解
                    📌3.opencv 图片、视频等操作
                    📌4.个人工作中的项目总结(纯干活)
              链接: https://blog.csdn.net/qq_28949847/article/details/128552785
🎉视频讲解: 以上记录,通过B站等平台进行了视频讲解使用,可搜索 ‘Python图像识别’ 进行观看
              B站:Python图像识别
              抖音:Python图像识别
              西瓜视频:Python图像识别


本文共总结了5种方式:
一. cv2.add
二. cv2.addWeighted
三. 按位运算(bitwise_not、bitwise_and、bitwise_or)
四. cv2.seamlessClone
五. 像素遍历

一. cv2.add

1. 简介

cv2.add(img1, img2) # 进行图片的加和
使用cv2.add()将两个图像相加,可以使用numpy中的矩阵加法来实现。但是在opencv中加法是饱和操作,也就是有上限值,numpy会对结果取模。

2. 参数说明:

cv2.add将两个图片进行加和,大于255的使用255计数

3. 注意:

需要合成的两个图片 大小必须一致

4. 对比numpy 和 cv2.add的区别

import numpy as np
import cv2

x = np.uint8([250])
y = np.uint8([10])
print(cv2.add(x, y))  # 250+10 = 260 => 255
print(x + y)  		  # 250+10 = 260 % 256 = 4

当图片为二值化图片(只有0和255),两者结果是一样的(用numpy的方式更简便一些)。

5. cv2.add(img1, img2)示例代码:

import cv2

img1=cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\wo\zly.jpg')
img2=cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\wo\yx.jpg')
res = cv2.add(img1, img2)
# 保存此方式可保持中文路径
cv2.imencode('.jpg', res)[1].tofile(r'D:\360MoveData\Users\Administrator\Desktop\wo\add_img.jpg')
cv2.imshow('input_image', res)
cv2.waitKey(0)

6.cv2.add代码效果

原图(yx.jpg)
在这里插入图片描述
原图(zly.jpg)
在这里插入图片描述
合成结果:
在这里插入图片描述

二. cv2.addWeighted

1. 简介

cv2.addWeighted(img1, 0.6, img2, 0.4, 0) 表示将两个图片进行重叠操作,可以自行设置两张图片的权重

2. 参数说明:

重叠后的像素表示: img10.6 + img20.4 + 0 ,0表示重叠的偏置项

3. 注意:

  1. 图片的size、channel、归一化格式都相同;
  2. 自行调节 0.4 0.6 参数看其他效果
  3. 当两个预值都为1 时,效果同cv2.add是一样的

4. cv2.addWeighted(img1, 0.6, img2, 0.4, 0)示例代码

i

import cv2

img1=cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\wo\zly.jpg')
img2=cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\wo\yx.jpg')
res = cv2.addWeighted(img1, 0.6, img2, 0.4, 0)
# 保存
cv2.imencode('.jpg', res)[1].tofile(r'D:\360MoveData\Users\Administrator\Desktop\wo\add_img.jpg')
cv2.imshow('input_image', res)
cv2.waitKey(0)

5. 代码合成效果

原图:img1 img2 依旧用上面的风景图片和张靓颖图片
合成效果:
在这里插入图片描述

三. 按位运算(bitwise_not、bitwise_and、bitwise_or)

1. 简介

问题:不管是cv2.add还是cv2.addWeighted在合成图片时都会改变原图片的样式,那么如何将一个图放到另一个图上去,不改变颜色,亮度等。那么位操作来了。。

首先来了解一下掩膜(mask)的概念:掩膜是用一副二值化图片对另外一幅图片进行局部的遮挡,看下图就一目了然了(借用网上图片):
在这里插入图片描述

cv2.add()用来叠加两幅图片,cv2.addWeighted()也是叠加两幅图片,但两幅图片的权重不一样
cv2.bitwise_and(), cv2.bitwise_not(), cv2.bitwise_or(), cv2.bitwise_xor()分别执行按位与/或/非/异或运算。掩膜就是用来对图片进行全局或局部的遮挡

2. cv2.bitwise_and() 代码示例(把一张图片,放入到另一张图片中)

import cv2

img1=cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\wo\zly.jpg')
img2=cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\wo\yx.jpg')

# 此处可以控制合成的位置(哪些位置进行改变)
# 这里两幅图一样大,不起作用
rows,cols,channels = img2.shape
roi = img1[0:rows, 0:cols ]

img2gray = cv2.cvtColor(img2,cv2.COLOR_BGR2GRAY)      # 将图片灰度化
cv2.imshow('img2gray',img2gray)
# 灰度图 把 大于175(不感兴趣)的值改为 255 ,也就是变为白色
ret, mask = cv2.threshold(img2gray, 175, 255, cv2.THRESH_BINARY)
cv2.imshow('mask',mask)
# 把mask取反,兴趣区域-->白色   无兴趣区域-->黑色
mask_not = cv2.bitwise_not(mask)
cv2.imshow('mask_not',mask_not)
# 对张靓颖图片和mask进行取与操作,作用相当于把mask中为黑色的部分,
# 在张靓颖图片中也附黑,白色部分不变。
img1_bg = cv2.bitwise_and(roi,roi,mask = mask)
cv2.imshow('img1_bg',img1_bg)
# 对风景图片和mask_not进行取与操作,作用相当于把mask中为黑色的部分,
# 在风景图片中也附黑,白色部分不变。
img2_fg = cv2.bitwise_and(img2,img2,mask = mask_not)
cv2.imshow('img2_fg',img2_fg)
# 相加即可
dst = cv2.add(img1_bg,img2_fg)
img1[0:rows, 0:cols ] = dst
# 保存
cv2.imencode('.jpg', dst)[1].tofile(r'D:\360MoveData\Users\Administrator\Desktop\wo\add_img.jpg')
cv2.imshow('dst', dst)
cv2.waitKey(0)

3. 代码效果

在这里插入图片描述

四. cv2.seamlessClone

1. 简介

无缝合成(Seamless Cloning)是opencv3的新特性。

利用这个新特性,我们可以从一个图像复制对象,将其粘贴到另一个图像中,同时使组合看起来无缝和自然。

2. 代码示例

import numpy as np
import cv2

# 把src 复制到 dst图片中去。dst为目标图片  src为 源图像
src=cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\wo\zly.jpg')
dst=cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\wo\yx.jpg')
cv2.imshow('dst', dst)
# 修改150的值,可以有不同的效果,这是为 一般可以设置为全白,也就是255
src_mask = 255 * np.ones(src.shape, src.dtype)
# 位置 此处图片不能偏移出去,大小控制好
center = (200,295)
# Clone seamlessly.  提供了两种方式 cv2.MIXED_CLONE 和 cv2.NORMAL_CLONE 结果不同的
output = cv2.seamlessClone(src, dst, src_mask, center, cv2.MIXED_CLONE)

# 保存
cv2.imencode('.jpg', output)[1].tofile(r'D:\360MoveData\Users\Administrator\Desktop\wo\add_img.jpg')
cv2.imshow('output', output)
cv2.waitKey(0)

3. 代码效果演示

在这里插入图片描述

五. 像素遍历

1.简介

像素遍历,就是指通过把所有的像素点遍历一遍,判断rgb的值,然后通过判断结果进行相对应操作。实际效果涉密不方便展示,就不放 图片了。

2. 代码展示

import cv2

img = cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\22\label457.png')
img1 = cv2.imread(r'D:\360MoveData\Users\Administrator\Desktop\33\19_19.tif')
img = cv2.cvtColor(img, cv2.COLOR_BGR2BGRA)

h = img.shape[0]
w = img.shape[1]
for i in range(w):
    for j in range(h):
        if img[j][i][0] != 0 or img[j][i][1] != 0 or img[j][i][2] != 0:
            img1[j][i] = (0, 0, 128)
cv2.imwrite(r'D:\360MoveData\Users\Administrator\Desktop\11\4.jpg', img1)

3. 代码效果

实际效果涉密不方便展示,就不放 图片了。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Python图像识别

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值