使图像背景透明

时间:2016-08-02 19:26:00

标签: python opencv image-processing computer-vision transparency

我有一张橙色和白色背景的图像。我想让白色背景透明。下面的代码使用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)

original post-grabcut mask final

1 个答案:

答案 0 :(得分:1)

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