PythonOpenCV随机粘贴图像

import cv2
import numpy as np
import random

# 读取两个图像
image1 = cv2.imread('image1.jpg')
image2 = cv2.imread('image2.jpg')

# 将image1转换为灰度图像
gray_image1 = cv2.cvtColor(image1, cv2.COLOR_BGR2GRAY)

# 创建掩码,黑色部分为0,非黑色部分为255
_, mask = cv2.threshold(gray_image1, 1, 255, cv2.THRESH_BINARY)

# 反转掩码
mask_inv = cv2.bitwise_not(mask)

# 获取图像1中有效区域的高度和宽度
height1, width1, _ = image1.shape

# 获取图像2的高度和宽度
height2, width2, _ = image2.shape

# 生成随机位置
random_y = random.randint(0, height2 - height1)
random_x = random.randint(0, width2 - width1)

# 创建ROI(Region of Interest),确保不超出图像2的范围
roi = image2[random_y:random_y + height1, random_x:random_x + width1]

# 创建ROI的反向掩码
roi_bg = cv2.bitwise_and(roi, roi, mask=mask_inv)

# 获取图像1中有效区域的前景
fg = cv2.bitwise_and(image1, image1, mask=mask)

# 合并前景和背景
dst = cv2.add(roi_bg, fg)

# 将合并后的图像放回图像2的相应位置
image2[random_y:random_y + height1, random_x:random_x + width1] = dst

# 显示结果
cv2.imshow('Merged Image', image2)
cv2.waitKey(0)
cv2.destroyAllWindows()
 

  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值