基于python和opencv的mask抠图叠加

背景照片:

这里写图片描述

logo:

这里写图片描述

合成效果:

这里写图片描述

代码:

import cv2 as cv, numpy as np
# Load two images
img1 = cv.imread('227351.jpg') # 背景
img2 = cv.imread('logo.png') # logo

# I want to put logo on top-left corner, So I create a ROI
rows,cols,channels = img2.shape
roi = img1[0:rows, 0:cols ]

# Now create a mask of logo and create its inverse mask also
img2gray = cv.cvtColor(img2,cv.COLOR_BGR2GRAY)
ret, mask = cv.threshold(img2gray, 254, 255, cv.THRESH_BINARY) # 这个254很重要
mask_inv = cv.bitwise_not(mask)

cv.imshow('mask',mask_inv)
# Now black-out the area of logo in ROI
img1_bg = cv.bitwise_and(roi,roi,mask = mask) # 这里是mask,我参考的博文写反了,我改正了,费了不小劲

# Take only region of logo from logo image.
img2_fg = cv.bitwise_and(img2,img2,mask = mask_inv) # 这里才是mask_inv

# Put logo in ROI and modify the main image
dst = cv.add(img1_bg,img2_fg)
img1[0:rows, 0:cols ] = dst

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

参考博文

https://blog.csdn.net/m0_37606112/article/details/79602537

### 回答1: Python OpenCV中的mask抠图是指使用掩码图像来提取图像中感兴趣的区域,将其与背景分离。通过将掩码图像与原始图像进行按位与操作,可以得到仅包含感兴趣区域的图像。这种技术在图像处理和计算机视觉中经常使用,例如在人脸识别、图像分割和物体识别等方面。 ### 回答2: Python OpenCV是一种功能强大的计算机视觉库,可以用于许多图像处理任务。在许多情况下,我们需要从图像中抠出特定的目标或物体,以进行分割、提取或跟踪等操作。这时,一个非常有用的技术是使用掩码(mask)抠图。 掩码抠图是将一些图像区域标记为感兴趣区域(Region of Interest),这些区域可以是任意形状或大小,然后将这些区域以外的部分置为黑色,以达到抠图的效果。 下面,我们介绍一下Python OpenCV中进行掩码抠图的方法: 第一步:读入图像,并将其转换为灰度。 import cv2 import numpy as np img = cv2.imread('image.jpg') gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) 第二步:创建一个掩码(mask)。 mask = np.zeros_like(gray) h, w = gray.shape[:2] mask[int(h/4):int(h*3/4), int(w/4):int(w*3/4)] = 255 在这个示例中,我们将创建一个大小与灰度图像相同的掩码,并将其中心的一部分标记为255(白色),其余部分都是0(黑色)。 第三步:将掩码应用于原始图像masked_img = cv2.bitwise_and(img, img, mask=mask) 使用cv2.bitwise_and()函数将原始图像和掩码相乘,以获得仅包含掩码区域的原始图像。 第四步:显示结果。 cv2.imshow('Original', img) cv2.imshow('Mask', mask) cv2.imshow('Masked Image', masked_img) cv2.waitKey(0) 最后,使用cv2.imshow()函数显示原始图像、掩码和抠图效果。cv2.waitKey()函数将暂停程序,直到按下任意键。 使用掩码抠图是一种通用的方法,可以用于许多图像处理和计算机视觉应用中。Python OpenCV的强大功能可以帮助我们实现各种高级图像处理操作,这也是它成为计算机视觉领域广泛使用的工具之一的原因之一。 ### 回答3: Python OpenCV是计算机视觉和图像处理领域的一个强大工具包,它可以实现图像的多种处理和分析。其中mask抠图技术是常用来将图像中指定对象分离出来的方法。 在Python OpenCV中,mask抠图的基本原理是基于像素值颜色的识别和提取,所以需要首先了解图像的色彩模式和色彩空间。 色彩模式指的是图像的颜色表示方式,包括RGB、HSV等模式;色彩空间指的是图像的色彩分布范围,主要有灰度图、二值图等。 在实现mask抠图中,可以采用以下步骤: 1. 加载图像并将其转换为HSV色彩模式。 2. 根据对象所在区域,手动绘制一个掩膜(mask)。 3. 通过掩膜提取目标对象。这可以通过将掩膜与原始图像进行逐像素运算来实现。 4. 将原始图像中有掩膜的部分提取出来,这就是我们需要的mask抠图结果。 下面通过示例代码进一步展示Python OpenCVmask抠图的具体实现: #导入库 import cv2 import numpy as np #读取图像并转换为HSV模式 img = cv2.imread('picture.jpg') img_hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV) #手动绘制掩膜mask mask = np.zeros_like(img_hsv[:,:,0]) cv2.circle(mask, (200,200), 100, 255, -1) #通过掩膜mask提取目标对象 target = cv2.bitwise_and(img, img, mask=mask) #显示结果图像 cv2.imshow('Original Image',img) cv2.imshow('Mask',mask) cv2.imshow('Target Image',target) cv2.waitKey(0) 以上代码中,我们通过手动绘制了一个圆形的掩膜mask,然后将掩膜与原始图像进行逐像素运算,从而提取出了原始图像中圆形区域内的目标对象。 总的来说,mask抠图技术是Python OpenCV中常用的图像处理技术之一,通过运用简单的掩膜mask技术,可以轻松实现图像分割和对象提取等功能。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值