python图像处理入门-提取轮廓

liftword6个月前 (01-08)技术文章85

提取图像中物体的轮廓,通常用在图像识别中,比如图像像素级分割,应用面比较广。

import cv2

import numpy as np

from skimage.measure import find_contours

img_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批量生成二维码图片

1、创建一个TXT文本文档,用来存放需要生成二维码的单号,每行一个单号,单号如下:14251564612316sw132132并保存。2、在scewm.py文件中输入代码,代码如下:import qr...

如何在 Python 中从图像中提取表格

大约一年前,我的任务是从文档中提取和构建数据,主要包含在表格中。我没有计算机视觉方面的先验知识,很难找到合适的“即插即用”解决方案。可用的选项要么是基于神经网络 (NN) 的先进解决方案,这些解决方案...

一篇带你实战的Python绘图Turtle库

Turtle库是Python语言中一个很流行的绘制图像的函数库,想象一个小乌龟,在一个横轴为x、纵轴为y的坐标系原点,(0,0)位置开始,它根据一组函数指令的控制,在这个平面坐标系中移动,从而在它爬行...

Python——如何写一个自动生成短视频的小工具

在如今这个短视频风靡的时代,大家都想在短视频领域分一杯羹。要是有个能自动生成短视频的小工具,那可就太实用啦!今天咱就来聊聊怎么写一个简易的自动生成短视频小工具代码,不管你是编程爱好者,还是想为自己的自...

Python批量重命名照片:让你的照片整理更加高效

Python批量重命名照片:让你的照片整理更加高效在日常生活中,我们经常会拍摄大量的照片,而这些照片的命名往往比较杂乱,甚至无法一眼辨识出每张照片的具体内容。尤其是当你拍摄了成百上千张照片时,整理和查...

用Python实现AI换脸

AI换脸要求把两张人脸的面部内容进行交替,并且能够尽量地进行拟合。我们首先在互联网上下载两张图片:(妹子证件照不好找,用下面两位哥的图片凑合一下)换脸技术在现在看来已经不是那么热门了,已经有很多应用软...