鱼C论坛

 找回密码
 立即注册
查看: 7592|回复: 5

看不懂用cv2.grabcut()方法抠图

[复制链接]
发表于 2018-4-9 17:26:50 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 JAY饭 于 2018-4-9 18:27 编辑

       原文在这里https://blog.csdn.net/u010682375/article/details/72791864
        里面第二次提到的掩码图片是哪一种呢,我试了几种都失败了,尤其是下面这段:
       
        ‘’实际上我是怎么做的呢?我们使用图像编辑软件打开输入图像,添加一个图层,使用笔刷工具在需要的地方使用白色绘制(比如头发,鞋子,球等);使用黑色笔刷在不需要的地方绘制                      (比如, logo,草地等)。然后将其他地方用灰色填充,保存成新的掩码图像。在 OpenCV 中导入这个掩模图像,根据新的
掩码图像对原来的掩模图像进行编辑。代码如下:

newmask = cv2.imread('newmask.jpg',0)
mask[newmask == 0] = 0
mask[newmask == 255] = 1
mask,bgdModel,fgdModel = cv2.grabCut(img, mask, None, bgdModel, fgdModel, 5, cv2.GC_INIT_WITH_MASK)
mask = np.where((mask ==2)|(mask ==0),0,1).astype('uint8') ‘’
      
        上面这段里面他这个‘newmask.jpg’到底是上面生成的 半成品抠图 ,还是这个半成品抠图上面的被手工标注的图层,还有里面说到的0像素,1像素真的不太明白他到底说的什么意思。
像素不都是0,0,0,0这种格式吗

下面发我实现的效果,始终不懂怎么去掉非前景部分,依次是,原图,第一次原始掩码的抠图,我用自己写的蒙版代码画的前景,背景蒙版图层,然后将其代入第二次掩码,最后是最后显示的图,效果不理想。
timg.jpg 3.jpg 5.png 6{SPVE(}(KJO$BA(VKPNI]P.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-4-9 17:28:10 | 显示全部楼层
本帖最后由 JAY饭 于 2018-4-9 18:28 编辑

抱歉忘了发悬赏,需要的话我在后面补,求大神指导下
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-9 17:31:26 | 显示全部楼层
老实说很头疼这种复制 别人翻译的国外文章却又不求甚解的博客,讲不讲清楚,搜遍全网,得不到关于python实现的完整过程。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-9 18:32:13 | 显示全部楼层
本帖最后由 JAY饭 于 2018-4-9 18:38 编辑

主代码,是我copy的,改动了一些,但不知道改的对不对,我真的不能理解它
,看不懂
  1. import cv2
  2. import numpy as np
  3. from matplotlib import pyplot as plt

  4. img = cv2.imread('timg.jpg')
  5. mask = np.zeros(img.shape[:2],np.uint8)
  6. bgdModel = np.zeros((1,65),np.float64)
  7. fgdModel = np.zeros((1,65),np.float64)
  8. rect = (100,10,415,471)
  9. cv2.grabCut(img, mask, rect, bgdModel, fgdModel,5,cv2.GC_INIT_WITH_RECT)
  10. mask2 = np.where((mask ==2)|(mask==0),0,1).astype('uint8')
  11. img = img*mask2[:,:,np.newaxis]

  12. cv2.imwrite('3.jpg',img)#这里讲第一次抠图保存


  13. newmask = cv2.imread('5.png',0)#这里将上面得到的图片,用蒙版处理后的图层,也就是图3

  14. # whereever it is marked white (sure foreground), change mask=1
  15. # whereever it is marked black (sure background), change mask=0
  16. mask[newmask == 0] = 0
  17. mask[newmask == 255] = 1

  18. mask, bgdModel, fgdModel = cv2.grabCut(img,mask,None,bgdModel,fgdModel,5,cv2.GC_INIT_WITH_MASK)

  19. mask = np.where((mask==2)|(mask==0),0,1).astype('uint8')
  20. img = img*mask[:,:,np.newaxis]
  21. plt.imshow(img),plt.colorbar(),plt.show()

复制代码


我自己写的绘制蒙版图层代码,随便划拉的几行,没有加工,因为这个不是重点
  1. import pygame
  2. from pygame.locals import *
  3. import sys

  4. bg = 255,255,255
  5. bg1 = 176,196,22
  6. size = width,hright = 516,481
  7. screen =pygame.display.set_mode(size)
  8. clock = pygame.time.Clock()

  9. img = pygame.image.load('3.jpg').convert_alpha()
  10. img1 = pygame.Surface(size)
  11. img1.fill(bg1)
  12. img1.set_alpha(100)
  13. pos = img.get_rect()

  14. w= False
  15. w1= False

  16. def write():
  17.     global w,w1
  18.     if w:
  19.         x,y = pygame.mouse.get_pos()
  20.         img1.set_at((x,y),(255,255,255,255))
  21.         img1.set_at((x+1,y),(255,255,255,255))
  22.         img1.set_at((x-1,y),(255,255,255,255))
  23.         img1.set_at((x+2,y),(255,255,255,255))
  24.         img1.set_at((x-2,y),(255,255,255,255))
  25.         img1.set_at((x,y+1),(255,255,255,255))
  26.         img1.set_at((x,y+2),(255,255,255,255))
  27.         img1.set_at((x,y-1),(255,255,255,255))
  28.         img1.set_at((x,y-2),(255,255,255,255))
  29.     if w1:
  30.         x,y = pygame.mouse.get_pos()
  31.         img1.set_at((x,y),(0,0,0,255))
  32.         img1.set_at((x+1,y),(0,0,0,255))
  33.         img1.set_at((x-1,y),(0,0,0,255))
  34. while True:
  35.     for e in pygame.event.get():
  36.         if e.type == pygame.QUIT:
  37.             sys.exit()
  38.         if e.type == MOUSEBUTTONDOWN:
  39.             if e.button == 1:
  40.                 w = True
  41.             elif e.button == 3:
  42.                 w1= True
  43.                
  44.         if e.type == MOUSEBUTTONUP:
  45.             if e.button == 1:
  46.                 w = False
  47.             elif e.button == 3:
  48.                 w1 = False

  49.         if e.type == KEYDOWN:
  50.             if e.key == K_a:
  51.                 img1.set_alpha(225)
  52.                 pygame.image.save(img1,'5.png')
  53.                
  54.     screen.fill(bg)
  55.     screen.blit(img,pos)
  56.     screen.blit(img1,pos)
  57.     write()
  58.     pygame.display.flip()
  59.     clock.tick(200)
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-9 19:18:56 | 显示全部楼层
已解决~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-7-9 07:14:18 | 显示全部楼层
请教大侠,修复模糊图片用什么函数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-12-29 06:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表