• 利用OpenCV实现图片中导线的识别


    下面是一个需求,识别图片中的导线,要在图像中检测导线,我们需要采用不同于直线检测的方法。由于OpenCV没有直接的曲线检测函数,如同它对直线提供的HoughLinesHoughLinesP,检测曲线通常需要更多的图像处理步骤和算法:

    1. 边缘检测:首先使用Canny边缘检测器检测图像中的边缘。

    2. 寻找轮廓:然后使用cv2.findContours来寻找边缘连接的轮廓。轮廓可能对应于图像中的曲线。

    3. 轮廓分析:分析这些轮廓,筛选出满足特定条件的轮廓,如长度、曲率等。

    4. 绘制轮廓:在原始图像上绘制这些轮廓。

    下面是成品代码:

    1. # coding=UTF-8
    2. import cv2
    3. import numpy as np
    4. def load_and_detect_curves(image_path, new_width, new_height):
    5. # 加载图像
    6. image = cv2.imread(image_path)
    7. if image is None:
    8. print("无法加载图像")
    9. return
    10. # 调整图像尺寸
    11. resized_image = cv2.resize(image, (new_width, new_height))
    12. # 将图像转换为灰度图
    13. gray_image = cv2.cvtColor(resized_image, cv2.COLOR_BGR2GRAY)
    14. # 应用高斯模糊
    15. blurred_image = cv2.GaussianBlur(gray_image, (5, 5), 0)
    16. # 使用Canny边缘检测器检测边缘
    17. edges = cv2.Canny(blurred_image, 50, 150, apertureSize=3)
    18. # 寻找轮廓
    19. contours, _ = cv2.findContours(edges, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
    20. # 筛选和绘制轮廓
    21. for contour in contours:
    22. # 可以在这里添加条件筛选特定轮廓
    23. if len(contour) > 100: # 例如,筛选长度大于100的轮廓
    24. cv2.drawContours(resized_image, [contour], -1, (0, 255, 0), 2)
    25. # 显示结果
    26. cv2.imshow('Detected Curves', resized_image)
    27. if cv2.waitKey(0) & 0xFF == ord('q'):
    28. cv2.destroyAllWindows()
    29. # 使用函数
    30. load_and_detect_curves('./images/2.png', 800, 600) # 替换为你的图像路径和期望的尺寸
    31. # load_and_detect_curves('./images/demo.jpg', 800, 600) # 替换为你的图像路径和期望的尺寸

    下面是运行效果:

  • 相关阅读:
    Redis群集
    《Python+Kivy(App开发)从入门到实践》自学笔记:简单UX部件——CheckBox复选框
    MySQL - 慢查询优化
    矩阵的概念
    面试官:介绍一下 Redis 三种集群模式
    阶段六-Day05-MyBatis3
    MyBatis-Plus DQL与其他知识点
    大数据是什么?可以做什么?
    Java异常、继承结构、处理异常、自定义异常、SpringBoot中全局捕获处理异常
    MFC|选择获取文件路径
  • 原文地址:https://blog.csdn.net/weixin_45498383/article/details/134524626