怎么在python中使用opencv查找图像中的较大的轮廓-创新互联
本篇文章给大家分享的是有关怎么在python中使用opencv查找图像中的较大的轮廓,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
成都创新互联专注为客户提供全方位的互联网综合服务,包含不限于网站制作、成都网站建设、清流网络推广、小程序设计、清流网络营销、清流企业策划、清流品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们大的嘉奖;成都创新互联为所有大学生创业者提供清流建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com具体如下:
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查找图像中的较大的轮廓,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。
分享标题:怎么在python中使用opencv查找图像中的较大的轮廓-创新互联
文章源于:http://scyanting.com/article/degeod.html