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)
输入图像:
输出图像:
来源:https://blog.csdn.net/qq_33757398/article/details/96174768
标签:opencv,最大轮廓
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
利用XSLT把ADO记录集转换成XML
2008-09-05 17:12:00
js图片水平翻转后垂直翻反转的特效代码
2009-03-06 15:33:00
mysql使用LOAD语句批量录入数据
2010-03-18 16:19:00
xhtml有哪些块级元素
2009-12-06 11:58:00
OpenCV MediaPipe实现颜值打分功能
2022-06-19 08:22:16
![](https://img.aspxhome.com/file/2023/9/114749_0s.jpg)
Python+logging输出到屏幕将log日志写入文件
2023-07-19 05:29:21
![](https://img.aspxhome.com/file/2023/5/59295_0s.png)
Python项目 基于Scapy实现SYN泛洪攻击的方法
2023-01-15 01:34:30
![](https://img.aspxhome.com/file/2023/8/88928_0s.jpg)
如何通过命令行进入python
2022-10-28 22:12:56
![](https://img.aspxhome.com/file/2023/9/79529_0s.png)
JSP EL表达式详细介绍
2023-07-02 22:32:32
![](https://img.aspxhome.com/file/2023/9/97899_0s.jpg)
限制文本框只能输入数字和小数点
2009-05-29 18:19:00
Python如何把十进制数转换成ip地址
2023-02-20 21:36:55
javascript中实现override,overload和类似c#中的property
2008-05-16 12:01:00
Python 字符串处理特殊空格\\xc2\\xa0\\t\\n Non-breaking space
2022-03-09 19:20:16
![](https://img.aspxhome.com/file/2023/2/107592_0s.png)
Python 中获取数组的子数组示例详解
2022-11-04 19:26:26
python模拟登录并且保持cookie的方法详解
2023-09-06 06:07:16
在Python中os.fork()产生子进程的例子
2022-08-12 18:15:27
PDO::getAttribute讲解
2023-06-06 02:58:22
Python中函数及默认参数的定义与调用操作实例分析
2022-01-15 05:16:31
![](https://img.aspxhome.com/file/2023/2/90302_0s.jpg)
Windows下使Python2.x版本的解释器与3.x共存的方法
2021-03-14 22:22:17
python中安装django模块的方法
2023-08-27 13:30:21
![](https://img.aspxhome.com/file/2023/1/65051_0s.png)