gpt4 book ai didi

python - 使图像背景透明

转载 作者:太空宇宙 更新时间:2023-11-03 22:50:33 24 4
gpt4 key购买 nike

我有一个橙色和白色背景的图像。我想让白色背景透明。下面的代码使用 grabcut 制作 mask 。然后我将图像拆分为 rgb channel 并在 alpha channel 上应用蒙版。您将从下面的图像中看到,后抓取和蒙版图像都可以。我还没弄清楚如何将蒙版应用到 alpha channel 。建议表示赞赏。

    im = cv2.imread(sourceimagefile)
cv2.imshow('original',im)
mask = np.zeros(im.shape[:2],np.uint8)
rect = (box[0][0], box[0][1], box[0][2]-box[0][0], box[0][3]-box[0][1])
bgdModel = np.zeros((1,65),np.float64)
fgdModel = np.zeros((1,65),np.float64)
cv2.grabCut(im,mask,rect,bgdModel,fgdModel,5,cv2.GC_INIT_WITH_RECT)
if len(np.where((mask==3)|(mask==1))[0])>0:
mask2 = np.where((mask==2)|(mask==0),0,1).astype('uint8')
mask2 = np.repeat(mask2[:,:,np.newaxis],3,axis=2)
else:
mask2 = np.zeros_like(im)
mask2[box[0][1]:box[0][3],box[0][0]:box[0][2],:] = 1
im2 = im*mask2
cv2.imshow('post-grabcut',im2)
minVal, maxVal, minLoc, maxLoc = cv2.minMaxLoc(mask)
flag, mask = cv2.threshold(mask, maxVal-1, 255, cv2.cv.CV_THRESH_BINARY)
cv2.imshow("mask", mask)
b, g, r = cv2.split(im2)
img_RGBA = cv2.merge((b, g, r, mask))
cv2.imshow("final",img_RGBA)

original post-grabcut mask final

最佳答案

根据较旧的 SO 问题,imshow 实际上不支持 alpha channel http://jepsonsblog.blogspot.com/2012/10/overlay-transparent-image-in-opencv.html但这是一篇旧帖子,支持 MAY 已添加,但我不确定

关于python - 使图像背景透明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38728907/

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