您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

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

51自学网 2021-10-30 22:49:31
  python
这篇教程python opencv 找出图像中的最大轮廓并填充(生成mask)写得很实用,希望能帮到您。

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

import cv2import numpy as npfrom PIL import Image from joblib import Parallelfrom 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 = 10parallel = 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 cv2import 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)的文章就介绍到这了,更多相关opencv最大轮廓内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


Python OpenCV招商银行信用卡卡号识别的方法
Python OpenCV 图像区域轮廓标记(框选各种小纸条)
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。