gpt4 book ai didi

python - Python 中的 OpenCV grabcut() 背景颜色和轮廓

转载 作者:太空狗 更新时间:2023-10-30 02:02:52 29 4
gpt4 key购买 nike

我正在使用 Python 和 OpenCV。我现在正在使用 grabcut() 裁剪出我想要的对象。这是我的代码:

img = cv2.imread('test.jpg')
img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
mask = np.zeros(img.shape[:2], np.uint8)

bgdModel = np.zeros((1, 65), np.float64)
fgdModel = np.zeros((1, 65), np.float64)

rect = (2,2,630,930)
cv2.grabCut(img,mask,rect,bgdModel,fgdModel,5,cv2.GC_INIT_WITH_RECT)

mask2 = np.where((mask==2)|(mask==0), 0,1).astype('uint8')
img = img*mask2[:,:, np.newaxis]

enter image description here enter image description here

然后,我尝试找出轮廓。

我试图通过下面的代码找到轮廓:

imgray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
ret,thresh = cv2.threshold(imgray,127,255,0)
im2, contours, hierarchy = cv2.findContours(thresh,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)

它返回一个轮廓数组,长度为48。当我把它画出来时: enter image description here

第一个问题是如何获取这个抓取切割的轮廓(数组)?

enter image description here第二个问题:如您所见,背景颜色为黑色。 如何将背景颜色更改为白色?

谢谢。

最佳答案

首先,您需要了解背景。为此必须从原始图像中减去掩模图像。然后将黑色背景更改为白色(或任何颜色)。然后返回添加蒙版图像。

import numpy as np
import cv2

cv2.namedWindow(‘image’, cv2.WINDOW_NORMAL)

#Load the Image
imgo = cv2.imread(‘input.jpg’)
height, width = imgo.shape[:2]

#Create a mask holder
mask = np.zeros(imgo.shape[:2],np.uint8)

#Grab Cut the object
bgdModel = np.zeros((1,65),np.float64)
fgdModel = np.zeros((1,65),np.float64)

#Hard Coding the Rect… The object must lie within this rect.
rect = (10,10,width-30,height-30)
cv2.grabCut(imgo,mask,rect,bgdModel,fgdModel,5,cv2.GC_INIT_WITH_RECT)
mask = np.where((mask==2)|(mask==0),0,1).astype(‘uint8’)
img1 = imgo*mask[:,:,np.newaxis]

#Get the background
background = imgo – img1

#Change all pixels in the background that are not black to white
background[np.where((background > [0,0,0]).all(axis = 2))] =[255,255,255]

#Add the background and the image
final = background + img1

#To be done – Smoothening the edges….

cv2.imshow(‘image’, final )

k = cv2.waitKey(0)

if k==27:
cv2.destroyAllWindows()

从网站获取的信息 https://nxtify.wordpress.com/2015/02/24/image-background-removal-using-opencv-in-python/

关于python - Python 中的 OpenCV grabcut() 背景颜色和轮廓,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38048650/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com