0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于OpenCV如何提取中心线

新机器视觉 来源:AI算法与图像处理 作者:AI算法与图像处理 2021-04-26 13:51 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

问题

前几天有个人问了我一个问题,问题是这样的,他有如下的一张二值图像:

怎么得到白色Blob中心线,他希望的效果如下:

显然OpenCV中常见的轮廓分析无法获得上面的中心红色线段,本质上这个问题是如何提取二值对象的骨架,提取骨架的方法在OpenCV的扩展模块中,另外skimage包也支持图像的骨架提取。这里就分别基于OpenCV扩展模块与skimage包来完成骨架提取,得到上述图示的中心线。

01安装skimage与opencv扩展包

Python环境下安装skimage图像处理包与opencv计算机视觉包,只需要分别执行下面两行命令:

pip install opencv-contrib-pythonpip install skimage

导入使用

from skimage import morphology import cv2 as cv

02使用skimage实现骨架提取

有两个相关的函数实现二值图像的骨架提取,一个是基于距离变换实现的medial_axis方法;另外一个是基于thin的skeletonize骨架提取方法。两个方法的代码实现分别如下:

1def skeleton_demo(image):

2 gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)

3 ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)

4 binary[binary == 255] = 1

5 skeleton0 = morphology.skeletonize(binary)

6 skeleton = skeleton0.astype(np.uint8) * 255

7 cv.imshow(“skeleton”, skeleton)

8 cv.waitKey(0)

9 cv.destroyAllWindows()

10

11

12def medial_axis_demo(image):

13 gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)

14 ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)

15 binary[binary == 255] = 1

16 skel, distance = morphology.medial_axis(binary, return_distance=True)

17 dist_on_skel = distance * skel

18 skel_img = dist_on_skel.astype(np.uint8)*255

19 contours, hireachy = cv.findContours(skel_img, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)

20 cv.drawContours(image, contours, -1, (0, 0, 255), 1, 8)

21

22 cv.imshow(“result”, image)

23 cv.waitKey(0)

24 cv.destroyAllWindows()

03使用OpenCV实现骨架提取

OpenCV的图像细化的骨架提取方法在扩展模块中,因此需要直接安装opencv-python的扩展包。此外还可以通过形态学的膨胀与腐蚀来实现二值图像的骨架提取,下面的代码实现就是分别演示了基于OpenCV的两种骨架提取方法。代码分别如下:

1def morph_find(image):

2 gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)

3 ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)

4 kernel = cv.getStructuringElement(cv.MORPH_CROSS, (3, 3))

5 finished = False

6 size = np.size(binary)

7 skeleton = np.zeros(binary.shape, np.uint8)

8 while (not finished):

9 eroded = cv.erode(binary, kernel)

10 temp = cv.dilate(eroded, kernel)

11 temp = cv.subtract(binary, temp)

12 skeleton = cv.bitwise_or(skeleton, temp)

13 binary = eroded.copy()

14

15 zeros = size - cv.countNonZero(binary)

16 if zeros == size:

17 finished = True

18

19 contours, hireachy = cv.findContours(skeleton, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)

20 cv.drawContours(image, contours, -1, (0, 0, 255), 1, 8)

21 cv.imshow(“skeleton”, image)

22 cv.waitKey(0)

23 cv.destroyAllWindows()

24

25

26def thin_demo(image):

27 gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)

28 ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)

29 thinned = cv.ximgproc.thinning(binary)

30 contours, hireachy = cv.findContours(thinned, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)

31 cv.drawContours(image, contours, -1, (0, 0, 255), 1, 8)

32 cv.imshow(“thin”, image)

33 cv.waitKey(0)

34 cv.destroyAllWindows()

运行结果如下:

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 图像
    +关注

    关注

    2

    文章

    1096

    浏览量

    42163
  • 骨架
    +关注

    关注

    0

    文章

    12

    浏览量

    8501
  • OpenCV
    +关注

    关注

    33

    文章

    651

    浏览量

    44430

原文标题:基于OpenCV实战:提取中心线

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    线架——数据中心的“隐形交通指挥官”

    在数据中心、服务器机房等高密度布线场景中,理线架如同一位“隐形交通指挥官”,通过科学管理线缆走向,确保数据传输的畅通无阻。它不仅是布线系统的“美容师”,更是保障网络稳定、提升运维效率的关键工具。 一
    的头像 发表于 11-07 11:25 188次阅读

    AMPMODU 2 mm线对板压接插座技术解析

    TE Connectivity(TE)AMPMODU 2MM线对板压接插座为微型电子产品提供经济高效且可靠的解决方案,与传统的2.54mm(0.100”)中心线连接器相比,占用的PCB空间减少38
    的头像 发表于 11-05 14:57 218次阅读

    零成本钢铁侠手套!树莓派+OpenCV 秒变手势遥控器!

    大家好,这是一个树莓派和OpenCV的连载专题。使用树莓派与OpenCV实现姿态估计和面部特征点追踪使用树莓派与OpenCV实现面部和运动追踪的云台系统使用树莓派和OpenCV实现手部
    的头像 发表于 08-16 16:16 893次阅读
    零成本钢铁侠手套!树莓派+<b class='flag-5'>OpenCV</b> 秒变手势遥控器!

    如何使用树莓派与OpenCV实现面部和运动追踪的云台系统?

    大家好,这是一个树莓派和OpenCV的连载专题。使用树莓派与OpenCV实现姿态估计和面部特征点追踪使用树莓派与OpenCV实现面部和运动追踪的云台系统使用树莓派和OpenCV实现手部
    的头像 发表于 08-14 17:45 982次阅读
    如何使用树莓派与<b class='flag-5'>OpenCV</b>实现面部和运动追踪的云台系统?

    如何使用树莓派+OpenCV实现姿态估计和面部特征点追踪?

    大家好,这是一个树莓派和OpenCV的连载专题。使用树莓派与OpenCV实现姿态估计和面部特征点追踪使用树莓派与OpenCV实现面部和运动追踪的云台系统使用树莓派和OpenCV实现手部
    的头像 发表于 08-13 17:44 991次阅读
    如何使用树莓派+<b class='flag-5'>OpenCV</b>实现姿态估计和面部特征点追踪?

    【GM-3568JHF开发板免费体验】OpenCV开发环境安装和计数程序开发

    检测、色彩转换)、视频分析(如运动检测、目标跟踪)、特征提取(如 SIFT 、 ORB 算法)、机器学习(如 SVM 、 决策树 )等。其跨平台特性使其能在 Linux 、 Windows
    发表于 08-09 13:30

    【GM-3568JHF开发板免费体验】OpenCV 视频目标跟踪 ( CamShift)

    目标区域的质心。 3)移动窗口:将窗口中心移动到质心位置。 4)调整窗口大小和方向:根据目标的尺寸和方向调整窗口。 5)迭代:重复步骤 2 到 4,直到窗口中心不再变化或达到最大迭代次数。 OpenCV
    发表于 08-09 13:19

    如何板端编译OpenCV并搭建应用--基于瑞芯微米尔RK3576开发板

    本文将介绍基于米尔电子MYD-LR3576开发板(米尔基于瑞芯微 RK3576开发板)的板端编译OpenCV及环境搭建方案的开发测试。摘自优秀创作者-短笛君 RK3576具有如下配置: 4
    发表于 08-08 17:14

    【Milk-V Duo S 开发板免费体验】SDK编译、人脸检测、OpenCV测试

    【Milk-V Duo S 开发板免费体验】SDK编译、人脸检测、OpenCV测试 本文介绍了 Milk-V Duo S 开发板实现 Buildroot SDK 镜像编译、基于 TDL 模型的人
    发表于 07-11 13:48

    编译opencv_camera_test找不到opencv.hpp怎么解决?

    1.取消makefile中的注释 2.在k230_sdk目录下进入docker环境后使用make mpp-apps编译 期待结果和实际结果 期待得到opencv_camera_test.elf文件
    发表于 06-23 06:14

    如何在k230上运行OpenCV的代码?

    如何在k230上运行OpenCV的代码
    发表于 06-17 06:06

    控制中心开机后无法识别CYUSB3014,除非重新插入USB线,这是怎么回事?

    和 PC 的电源,或者仅关闭 PCBA 的电源时,控制中心偶尔会在开机后显示无设备。 遇到这种情况,只能把USB3.0的线拔掉再插上去,就好了。 添加:PC的操作系统是win10。 如下情况就不行: 接下来重新插上电源就OK了。
    发表于 05-12 06:40

    为LSDK构建opencv时遇到的问题求解

    我正在尝试使用 flex-builder 来运行 bld -c opencv -r ubuntu:桌面 我想要最新版本的 OpenCV。在我的 sdk.yml 文件中,我将 opencv
    发表于 03-26 08:26

    使用OpenCV保存从摄像头捕获的视频时更改颜色输出视频收到警告怎么解决?

    保存了从配备 OpenCV* 的摄像头捕获的视频。 生成更改的颜色输出视频。 收到警告:[ INFO:0] global .。/opencv/modules/core/src/utils
    发表于 03-05 07:20

    如何用OpenCV进行手势识别--基于米尔全志T527开发板

    本文将介绍基于米尔电子MYD-LT527开发板(米尔基于全志T527开发板)的OpenCV手势识别方案测试。摘自优秀创作者-小火苗米尔基于全志T527开发板一、软件环境安装1.安装OpenCVsudoapt-getinstalllibopencv-devpython3-openc
    的头像 发表于 12-13 08:04 1769次阅读
    如何用<b class='flag-5'>OpenCV</b>进行手势识别--基于米尔全志T527开发板