前言:
目前朋友们对“python输出图形”都比较珍视,看官们都想要知道一些“python输出图形”的相关资讯。那么小编同时在网上收集了一些对于“python输出图形””的相关知识,希望看官们能喜欢,你们快快来了解一下吧!提取图像中物体的轮廓,通常用在图像识别中,比如图像像素级分割,应用面比较广。
import cv2import numpy as npfrom skimage.measure import find_contoursimg_path = "D://001.jpg"img_bgr = cv2.imread(img_path) #读取图像rows = img_bgr.shape[0] #图像的宽度cols = img_bgr.shape[1] #图像的长度img_gray = cv2.cvtColor(img_bgr, cv2.COLOR_BGR2GRAY) #转为灰度图_, thres = cv2.threshold(img_gray, 80, 255, cv2.THRESH_BINARY) #阈值二值化cv2.imwrite("D://001_thres.jpg", thres) #保存阈值化后的图mask = np.zeros((rows, cols), dtype=np.uint8)mask[:, :] = np.where(thres[:, :] == 0, 0, 1) #构建二值图掩码contours = find_contours(mask, 0.5) #寻找二值图的轮廓verts = np.fliplr(contours[0]) - 1 #物体的外轮廓通常是最长的一个,这里只找物体的外轮廓for k in range(len(verts) - 1): spos = (int(verts[k][0]), int(verts[k][1])) epos = (int(verts[k + 1][0]), int(verts[k + 1][1])) cv2.line(img_bgr, spos, epos, (0, 0, 255), 2) #将外轮廓用红色的线绘制到原图上 cv2.imwrite("D://001_contour.jpg", img_bgr) #保存绘制了红色外轮廓的图
每步的效果图如下:
涉及的函数介绍:
版权声明:
本站文章均来自互联网搜集,如有侵犯您的权益,请联系我们删除,谢谢。
标签: #python输出图形 #二值图像轮廓提取算法 #图像边缘提取的原理