python使用OpenCV模块实现图像的融合

三种融合

注意融合时,一般来说两个图像的尺寸是一样大小的,如果大小不一样,需要把大的图像的某一部分先截出来,与小的图先融合,再作为整体替换掉原来大图中抠出的小图部分。

"""
# @Time    :  2020/4/3
# @Author  :  JMChen
"""
import cv2 as cv

img1 = cv.imread('logo.png')
img2 = cv.imread('lena.png')
# 在lena.png获取和logo.png大小相同的ROI
rows, cols, channels = img1.shape
img_ROI1 = img2[0:rows, 0:cols]

img_ROI2 = cv.addWeighted(img1, 0.7, img_ROI1, 0.3, 0)
img2[0:rows, 0:cols] = img_ROI2

# 显示混合后的图片
cv.imshow('img2', img2)
cv.waitKey(0)

# 将两幅图像(lena.png)+ (logo.png)进行融合
img2 = cv.imread('lena.png')
# 1,在lena.png获取和logo.png大小相同的ROI
img_ROI1 = img2[0:rows, 0:cols]

# 2,基于logo.png的灰度图,利用简单的阈值分割创建一个掩模
img1_gray = cv.cvtColor(img1, cv.COLOR_BGR2GRAY)
ret, mask = cv.threshold(img1_gray, 10, 255, cv.THRESH_BINARY)
mask_inv = cv.bitwise_not(mask)

# 3,与掩模进行按位与操作,去掉logo中非0部分,得到新的图
new_img2 = cv.bitwise_and(img_ROI1, img_ROI1, mask=mask_inv)

# 4,将新图与logo相加,然后将这一部分替换掉原始图像的img_ROI1部分
dst = cv.add(img1, new_img2)
img2[0:rows, 0:cols] = dst

cv.imshow('res', img2)
cv.waitKey(0)
cv.destroyAllWindows()

# 实现另一种融合
img2 = cv.imread('lena.png')
img_ROI1 = img2[0:rows, 0:cols]

dst_1 = cv.addWeighted(img_ROI1, 0.55, dst, 0.45, 0)
img2[0:rows, 0:cols] = dst_1

cv.imshow('res_2', img2)
cv.waitKey(0)
cv.destroyAllWindows()

效果如下:
cansu
在这里插入图片描述

相关的比例参数可以自己按需调

seamlessClone函数是OpenCV中用于图像融合的函数,它可以将源图像的一部分无缝地嵌入到目标图像中。该函数的使用步骤如下: 1. 导入OpenCV模块和numpy模块。 2. 读入目标图像和源图像,确保它们的大小相同。 3. 根据需要,选择源图像中需要嵌入到目标图像中的区域,并提取该区域的掩码。 4. 调用seamlessClone函数,将源图像嵌入到目标图像中。该函数的参数包括目标图像、源图像、掩码、嵌入区域的中心坐标和嵌入模式。嵌入模式有三种:NORMAL_CLONE,MIXED_CLONE和MONOCHROME_TRANSFER。其中,NORMAL_CLONE是最常用的模式。 5. 显示嵌入后的图像。 下面是一个简单的例子: ```python import cv2 import numpy as np # 读入目标图像和源图像 target = cv2.imread('target.jpg') source = cv2.imread('source.jpg') # 确保目标图像和源图像大小相同 source = cv2.resize(source, (target.shape[1], target.shape[0])) # 选择源图像中需要嵌入到目标图像中的区域,并提取该区域的掩码 mask = np.zeros_like(source) mask[100:300, 100:300] = 255 # 调用seamlessClone函数,将源图像嵌入到目标图像中 center = (500, 500) result = cv2.seamlessClone(source, target, mask, center, cv2.NORMAL_CLONE) # 显示嵌入后的图像 cv2.imshow('result', result) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在上面的例子中,我们将源图像中的一个区域嵌入到了目标图像中,并显示了嵌入后的结果。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值