python OpenCV GrabCut使用实例解析


Posted in Python onNovember 11, 2019

这篇文章主要介绍了python OpenCV GrabCut使用实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

先上一个效果图:

python OpenCV GrabCut使用实例解析

使用Python3.7+OpenCV 3.x.

需要引入 numpy库。

在图上用鼠标左键和右键标记前景和后景即可.

如果需要重新标记图像,关闭程序重新运行.

以下是具体实现代码

# -*- coding:utf-8 -*-

'''
  Python: 3.5.7
  opencv 3.x

  在图上用鼠标左键和右键标记前景和后景即可.
  如果需要重新标记图像,关闭程序重新运行.
  By Ynxf http://www.zhouws.com
'''

import cv2
import numpy as np
import time

img_src = '../test_images/3.jpg'

drawing = False
mode = False

class GrabCut:
  def __init__(self, t_img):
    self.img = t_img
    self.img_raw = img.copy()
    self.img_width = img.shape[0]
    self.img_height = img.shape[1]
    self.scale_size = 640 * self.img_width // self.img_height
    if self.img_width > 640:
      self.img = cv2.resize(self.img, (640, self.scale_size), interpolation=cv2.INTER_AREA)
    self.img_show = self.img.copy()
    self.img_gc = self.img.copy()
    self.img_gc = cv2.GaussianBlur(self.img_gc, (3, 3), 0)
    self.lb_up = False
    self.rb_up = False
    self.lb_down = False
    self.rb_down = False
    self.mask = np.full(self.img.shape[:2], 2, dtype=np.uint8)
    self.firt_choose = True


# 鼠标的回调函数
def mouse_event2(event, x, y, flags, param):
  global drawing, last_point, start_point
  # 左键按下:开始画图
  if event == cv2.EVENT_LBUTTONDOWN:
    drawing = True
    last_point = (x, y)
    start_point = last_point
    param.lb_down = True
    print('mouse lb down')
  elif event == cv2.EVENT_RBUTTONDOWN:
    drawing = True
    last_point = (x, y)
    start_point = last_point
    param.rb_down = True
    print('mouse rb down')
  # 鼠标移动,画图
  elif event == cv2.EVENT_MOUSEMOVE:
    if drawing:
      if param.lb_down:
        cv2.line(param.img_show, last_point, (x,y), (0, 0, 255), 2, -1)
        cv2.rectangle(param.mask, last_point, (x, y), 1, -1, 4)
      else:
        cv2.line(param.img_show, last_point, (x, y), (255, 0, 0), 2, -1)
        cv2.rectangle(param.mask, last_point, (x, y), 0, -1, 4)
      last_point = (x, y)
  # 左键释放:结束画图
  elif event == cv2.EVENT_LBUTTONUP:
    drawing = False
    param.lb_up = True
    param.lb_down = False
    cv2.line(param.img_show, last_point, (x,y), (0, 0, 255), 2, -1)
    if param.firt_choose:
      param.firt_choose = False
    cv2.rectangle(param.mask, last_point, (x,y), 1, -1, 4)
    print('mouse lb up')
  elif event == cv2.EVENT_RBUTTONUP:
    drawing = False
    param.rb_up = True
    param.rb_down = False
    cv2.line(param.img_show, last_point, (x,y), (255, 0, 0), 2, -1)
    if param.firt_choose:
      param.firt_choose = False
      param.mask = np.full(param.img.shape[:2], 3, dtype=np.uint8)
    cv2.rectangle(param.mask, last_point, (x,y), 0, -1, 4)
    print('mouse rb up')

if __name__ == '__main__':
  img = cv2.imread(img_src)
  if img is None:
    print('error: 图像为空')
  g_img = GrabCut(img)

  cv2.namedWindow('image')
  # 定义鼠标的回调函数
  cv2.setMouseCallback('image', mouse_event2, g_img)
  while (True):
    cv2.imshow('image', g_img.img_show)
    if g_img.lb_up or g_img.rb_up:
      g_img.lb_up = False
      g_img.rb_up = False
      start = time.process_time()
      bgdModel = np.zeros((1, 65), np.float64)
      fgdModel = np.zeros((1, 65), np.float64)

      rect = (1, 1, g_img.img.shape[1], g_img.img.shape[0])
      print(g_img.mask)
      mask = g_img.mask
      g_img.img_gc = g_img.img.copy()
      cv2.grabCut(g_img.img_gc, mask, rect, bgdModel, fgdModel, 5, cv2.GC_INIT_WITH_MASK)
      elapsed = (time.process_time() - start)
      mask2 = np.where((mask == 2) | (mask == 0), 0, 1).astype('uint8') # 0和2做背景
      g_img.img_gc = g_img.img_gc * mask2[:, :, np.newaxis] # 使用蒙板来获取前景区域
      cv2.imshow('result', g_img.img_gc)

      print("Time used:", elapsed)

    # 按下ESC键退出
    if cv2.waitKey(20) == 27:
      break

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python编程实现线性回归和批量梯度下降法代码实例
Jan 04 Python
python批量修改图片大小的方法
Jul 24 Python
Face++ API实现手势识别系统设计
Nov 21 Python
详解django中url路由配置及渲染方式
Feb 25 Python
详解python中init方法和随机数方法
Mar 13 Python
Python pygame绘制文字制作滚动文字过程解析
Dec 12 Python
python 实现按对象传值
Dec 26 Python
python 瀑布线指标编写实例
Jun 03 Python
python使用matplotlib:subplot绘制多个子图的示例
Sep 24 Python
python OpenCV学习笔记
Mar 31 Python
浅谈python中的多态
Jun 15 Python
Python通用验证码识别OCR库ddddocr的安装使用教程
Jul 07 Python
Python上下文管理器用法及实例解析
Nov 11 #Python
Django 请求Request的具体使用方法
Nov 11 #Python
浅谈Python类中的self到底是干啥的
Nov 11 #Python
python 调试冷知识(小结)
Nov 11 #Python
通过 Django Pagination 实现简单分页功能
Nov 11 #Python
python机器学习实现决策树
Nov 11 #Python
Python SQLAlchemy入门教程(基本用法)
Nov 11 #Python
You might like
浅析php中抽象类和接口的概念以及区别
2013/06/27 PHP
PHP获取本周第一天和最后一天示例代码
2014/02/24 PHP
php上传图片并压缩的实现方法
2015/12/22 PHP
javascript中的location用法简单介绍
2007/03/07 Javascript
ASP.NET jQuery 实例12 通过使用jQuery validation插件简单实现用户注册页面验证功能
2012/02/03 Javascript
JavaScript检查某个function是否是原生代码的方法
2014/08/20 Javascript
使用js dom和jquery分别实现简单增删改
2014/09/11 Javascript
javascript 动态创建表格
2015/01/08 Javascript
JS中的hasOwnProperty()和isPrototypeOf()属性实例详解
2016/08/11 Javascript
Vuejs第十二篇之动态组件全面解析
2016/09/09 Javascript
JavaScript计算值然后把值嵌入到html中的实现方法
2016/10/29 Javascript
js正则表达式惰性匹配和贪婪匹配用法分析
2016/12/26 Javascript
vue小图标favicon不显示的解决方案
2017/09/19 Javascript
Vue异步加载about组件
2017/10/31 Javascript
vue引入ueditor及node后台配置详解
2018/01/03 Javascript
React Native使用fetch实现图片上传的示例代码
2018/03/07 Javascript
js嵌套的数组扁平化:将多维数组变成一维数组以及push()与concat()区别的讲解
2019/01/19 Javascript
在vue中获取微信支付code及code被占用问题的解决方法
2019/04/16 Javascript
如何利用javascript接收json信息并进行处理
2020/08/06 Javascript
Python自定义类的数组排序实现代码
2016/08/28 Python
基于Python中单例模式的几种实现方式及优化详解
2018/01/09 Python
python如何定义带参数的装饰器
2018/03/20 Python
pandas 实现字典转换成DataFrame的方法
2018/07/04 Python
Python实现的IP端口扫描工具类示例
2019/02/15 Python
Python队列RabbitMQ 使用方法实例记录
2019/08/05 Python
你应该知道的Python3.6、3.7、3.8新特性小结
2020/05/12 Python
OpenCV Python实现图像指定区域裁剪
2021/03/12 Python
call在Python中改进数列的实例讲解
2020/12/09 Python
美容院考勤制度
2014/01/30 职场文书
手机促销活动方案
2014/02/05 职场文书
爽歪歪广告词
2014/03/20 职场文书
水污染治理工程专业求职信
2014/06/14 职场文书
2014年检察院个人工作总结
2014/12/09 职场文书
雷锋的观后感
2015/06/10 职场文书
装修安全责任协议书
2016/03/22 职场文书
Java基于Dijkstra算法实现校园导游程序
2022/03/17 Java/Android