python透明图片合并_如何使用Scikitimag将一个透明的png图像与另一个图像合并

受user8190410的答案启发,我构建了自己的函数来实现:from skimage import data

import numpy as np

x, y = 100, 100

background = data.imread('background.jpg') / 255.

image = data.imread('image.png') / 255.

background_height, background_width, background_depth = background.shape

image_height, image_width, image_depth = image.shape

template = np.zeros((background_height, background_width, image_depth))

template[y : y + image_height, x : x + image_width, :] = image

mask = np.stack([template[:,:,3] for _ in range(3)], axis = 2)

inv_mask = 1. - mask

result = background[:,:,:3] * inv_mask + template[:,:,:3] * mask

plt.figure(figsize = (15, 15))

plt.subplot(1, 3, 2)

plt.imshow(image)

plt.subplot(1, 3, 1)

plt.imshow(background)

plt.subplot(1, 3, 3)

plt.imshow(result)

plt.tight_layout()

plt.show()

nGGaC.png

如果我能做些什么来提高计算速度,请告诉我

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!要将一个图像中的多边形复制到另一个图像,可以使用以下步骤: 1. 使用 OpenCV 读取源图像和目标图像。 ```python import cv2 src_img = cv2.imread('source_image.jpg') dst_img = cv2.imread('destination_image.jpg') ``` 2. 使用 OpenCV 的 `cv2.fillPoly()` 函数在源图像中绘制多边形。 ```python import numpy as np # 定义多边形顶点坐标 pts = np.array([[100, 100], [200, 50], [300, 150], [200, 200]], np.int32) # 在源图像中绘制多边形 cv2.fillPoly(src_img, [pts], (255, 255, 255)) ``` 3. 使用 OpenCV 的 `cv2.bitwise_and()` 函数将源图像中的多边形与目标图像进行逐像素的“与”操作,得到重叠区域。 ```python # 将源图像中的多边形与目标图像进行“与”操作 mask = cv2.bitwise_and(src_img, dst_img) ``` 4. 使用 OpenCV 的 `cv2.addWeighted()` 函数将重叠区域叠加到目标图像上。 ```python # 将重叠区域叠加到目标图像上 result = cv2.addWeighted(mask, 1, dst_img, 1, 0) ``` 完整代码如下: ```python import cv2 import numpy as np # 读取源图像和目标图像 src_img = cv2.imread('source_image.jpg') dst_img = cv2.imread('destination_image.jpg') # 定义多边形顶点坐标 pts = np.array([[100, 100], [200, 50], [300, 150], [200, 200]], np.int32) # 在源图像中绘制多边形 cv2.fillPoly(src_img, [pts], (255, 255, 255)) # 将源图像中的多边形与目标图像进行“与”操作 mask = cv2.bitwise_and(src_img, dst_img) # 将重叠区域叠加到目标图像上 result = cv2.addWeighted(mask, 1, dst_img, 1, 0) # 显示结果 cv2.imshow('Result', result) cv2.waitKey(0) cv2.destroyAllWindows() ``` 注意:在使用 `cv2.fillPoly()` 函数绘制多边形时,需要确保多边形的顶点坐标顺序是按照顺时针或逆时针排列的,否则可能会出现意想不到的结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值