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

news/2024/11/25 7:53:58/

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

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

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

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

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

下面是成品代码:

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

下面是运行效果:


http://www.ppmy.cn/news/1232170.html

相关文章

创新无界:通义灵码在测试过程中展现的独特魅力

通义灵码基于通义大模型,提供代码智能生成、研发智能问答能力。本文就来介绍下通义灵码在测试过程中的应用。 操作手册: 通义灵码, 阿里云提供的一款基于通义大模型的智能编码辅助工具_云效-阿里云帮助中心 1. 什么是通义灵码 是阿里云出品的一款基于通…

mac添加Chrome插件的方法

如果是.crx的插件 更改后缀crx为zip 后续步骤同下文.zip文件 如果是.zip的插件 使用终端进行解压 注意不要用解压工具解压,一定要用终端,命令行解压 // 进入到“插件名.zip”文件的目录下,输入下面命令: unzip 插件名.zip -…

企业办公文件数据防泄密系统 | 文件、文档、设计图纸、源代码、音视频等核心数据资料防止外泄!

天锐绿盾防泄密软件采用智能透明加密技术,对文件、文档、图纸、源代码、音视频等数据进行加密保护,防止数据泄露。这种加密技术是内核级透明加密技术,可以在不影响员工正常工作的情况下,对需要保护的数据进行加密操作。 PC端访问地…

opencv-python 印刷质量缺陷的视觉检测

Windows10PythonYolov8ONNX图片缺陷识别,并在原图中标记缺陷,有onnx模型则无需配置,无需训练。 ** PythonYolov8ONNX实时缺陷目标检测原文 labelimg使用指南 windows使用YOLOv8训练自己的模型(0基础保姆级教学) pyth…

【C+进阶之路】第六篇:C++11

文章目录 一、【C】C11(1)二、【C】C11(2) 一、【C】C11(1) 【C】C11(1) 二、【C】C11(2) 【C】C11(2) 🌹&#x1f33…

11.21序列检测,状态机比较与代码,按键消抖原理

序列检测 用一个atemp存储之前的所有状态,即之前出现的七位 含无关项检测 要检测011XXX110 对于暂时变量的高位,位数越高就是越早出现的数字,因为新的数字存储在TEMP的最低位 不重叠序列检测 ,一组一组 011100 timescale 1ns…

vue中原生H5拖拽排序_拖拽图片也是同样的道理

原文地址【vue中原生H5拖拽排序_拖拽图片也是同样的道理】 H5有基于拖拽的事件机制&#xff0c;如果你还不熟悉&#xff0c;请看我之前的文章【拖拽上传】中有介绍。 原生拖拽API实现 由于比较简单直接上代码了&#xff1a; <!DOCTYPE html> <html lang"en&qu…

目标检测YOLO系列从入门到精通技术详解100篇-【目标检测】目标视觉检测

目录 前言 算法原理 1 目标视觉检测的基本流程 1.1 区域建议 1.2 特征表示