python opencv 找出图像中的最大轮廓并填充(生成mask)

作者:深山里的小白羊 时间:2021-01-14 23:42:10 

本文主要介绍了python opencv 找出图像中的最大轮廓并填充,分享给大家,具体如下:


import cv2
import numpy as np
from PIL import Image

from joblib import Parallel
from joblib import delayed
# Parallel 和 delayed是为了使用多线程处理
# 使用前需要安装joblib:pip install joblib

# img_stack的shape为:num, h, w
# 是三维的图像,可以理解为是num张二维的图像组成
# mask是用来保存最后的结果的
mask = np.ones_like(img_stack)
for i in range(num):
 # 阈值化
 _, binaryzation = cv2.threshold(img_stack[i], 5, 255, cv2.THRESH_BINARY_INV)
 # 找到所有的轮廓
 contours, _ = cv2.findContours(binaryzation, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)
 area = []
 # 找到最大的轮廓
 for k in range(len(contours)):
   area.append(cv2.contourArea(contours[k]))
 max_idx = np.argmax(np.array(area))
 # cv2.fillContexPoly(mask[i], contours[max_idx], 0)
 # 填充最大的轮廓
 cv2.drawContours(mask[i], contours, max_idx, 0, cv2.FILLED)
 del area

# 保存
def _write_mask(mask, i):
 Image.fromarray(mask.astype(np.uint8)*255).save(os.path.join(path, 'm%d.png' % i))

# 使用多线程进行保存
num_cores = 10
parallel = Parallel(n_jobs=num_cores, backend='threading')
parallel(delayed(_write_mask)(mask[i, :, :], i) for i in range(0, num))

之前偷懒直接将项目里面的代码段扣下来放在这里,误导了大家,抱歉

这次我重新放一个完整版本,希望对大家有所帮助~~

代码在python 3.7.6 和opencv-python 4.3.0下测试成功


import cv2
import numpy as np

# 以灰度方式读取图像
img = cv2.imread('img.png', cv2.IMREAD_GRAYSCALE)
mask = img.copy()

# 二值化,100为阈值,小于100的变为255,大于100的变为0
# 也可以根据自己的要求,改变参数:
# cv2.THRESH_BINARY
# cv2.THRESH_BINARY_INV
# cv2.THRESH_TRUNC
# cv2.THRESH_TOZERO_INV
# cv2.THRESH_TOZERO
_, binaryzation = cv2.threshold(img, 100, 255, cv2.THRESH_BINARY_INV)

# 找到所有的轮廓
contours, _ = cv2.findContours(binaryzation, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)

area = []

# 找到最大的轮廓
for k in range(len(contours)):
area.append(cv2.contourArea(contours[k]))
max_idx = np.argmax(np.array(area))

# 填充最大的轮廓
mask = cv2.drawContours(mask, contours, max_idx, 0, cv2.FILLED)

# 保存填充后的图像
cv2.imwrite('masked.png', mask)

输入图像:

python opencv 找出图像中的最大轮廓并填充(生成mask)

输出图像:

python opencv 找出图像中的最大轮廓并填充(生成mask)

来源:https://blog.csdn.net/qq_33757398/article/details/96174768

标签:opencv,最大轮廓
0
投稿

猜你喜欢

  • python实现求两个字符串的最长公共子串方法

    2021-08-02 21:14:08
  • MySQL Workbench操作图文详解(史上最细)

    2024-01-14 01:44:14
  • mysql5.5与mysq 5.6中禁用innodb引擎的方法

    2024-01-21 13:55:42
  • vue+echarts实现动态折线图的方法与注意

    2023-07-02 16:29:06
  • 详解Python装饰器之@property

    2021-06-25 15:55:45
  • python opencv 直方图反向投影的方法

    2022-10-07 18:37:37
  • 对python实现二维函数高次拟合的示例详解

    2021-06-30 11:24:06
  • zend framework文件上传功能实例代码

    2024-05-05 09:17:17
  • PHPStudy下如何为Apache安装SSL证书的方法步骤

    2023-11-14 18:57:09
  • asp sqlserver 执行存储过程返回记录集报对象关闭时不允许操作

    2011-03-11 10:57:00
  • ASP GetRef 函数指针试探

    2011-03-16 11:09:00
  • SQL Server里书签查找的性能伤害

    2024-01-13 08:19:05
  • python中用Scrapy实现定时爬虫的实例讲解

    2023-07-26 05:47:01
  • virtualenv隔离Python环境的问题解析

    2023-11-13 02:00:13
  • SQL server使用自定义函数以及游标

    2024-01-23 23:55:32
  • python遗传算法之单/多目标规划问题

    2021-09-09 20:27:24
  • 浅谈Python2获取中文文件名的编码问题

    2021-08-11 08:18:45
  • Python 使用 Pillow 模块给图片添加文字水印的方法

    2022-06-13 04:13:37
  • python 对key为时间的dict排序方法

    2021-03-22 17:09:59
  • 在pyCharm中下载第三方库的方法

    2022-12-17 10:37:16
  • asp之家 网络编程 m.aspxhome.com