我有一张橙色和白色背景的图像。我想让白色背景透明。下面的代码使用grabcut制作一个掩码。然后我将图像分割成rgb通道并在alpha通道上应用蒙版。您将从下面的图像中看到后抓图和蒙版图像都可以。我还没有弄清楚如何将遮罩应用到alpha通道。建议表示赞赏。
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)
答案 0 :(得分:1)
根据较旧的SO问题,imshow实际上并不支持alpha频道http://jepsonsblog.blogspot.com/2012/10/overlay-transparent-image-in-opencv.html,但这是一个旧帖子并且已添加 MAY ,但我不确定