python opencv 直线检测

直线检测

前期准备

import cv2
import numpy as np

# 读取图片
img = cv2.imread(r"C:\Users\HONOR\Desktop\12.png")
# 灰度转换
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 二值化
# reg, img = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY)
# 显示二值化后的图像
# cv2.imshow("thresh", img)

canny边缘检测

在进行检测直线之前需要进行边缘检测

# 检测直线
# 首先进行边缘检测
canny = cv2.Canny(gray, 30, 150)
  • 语法格式:

    cv2.Canny(image, threshold1, threshold2[, edges[, apertureSize[, L2gradient]]]) -> edges
    
    - image:输入图像,必须为单通道灰度图像;
    - threshold1:第一个阈值,用于边缘连接;
    - threshold2:第二个阈值,用于边缘检测;
    - edges:输出的边缘图像;
    - apertureSize:Sobel 算子的大小,可选值为 357,默认值为 3- L2gradient:是否使用 L 2 L_2L 2范数计算梯度大小,可选值为 TrueFalse,默认值为 False

直线检测

# 使用霍夫变换来得出直线的检测结果
# 霍夫变换进行直线检测
lines = cv2.HoughLines(canny, 1, np.pi / 180, 180)
lines1 = lines[:, 0, :]
for rho, theta in lines1[:]:
    a = np.cos(theta)
    b = np.sin(theta)
    x0 = a * rho
    y0 = b * rho
    x1 = int(x0 + 3000 * (-b))
    y1 = int(y0 + 3000 * (a))
    x2 = int(x0 - 3000 * (-b))
    y2 = int(y0 - 3000 * (a))
    cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2)
  • 语法格式:
cv.HoughLines(image, rho, theta, threshold[, lines[, srn[, stn[, min_theta[, max_theta]]]]]) -> lines

- lines:数组,每一个元素都是一条直线对应的(ρ, θ),ρ以像素为单位,θ以弧度为单位。
- image:输入图像,需要是二值图像,所以在应用hough变换之前应用阈值或canny边缘检测。
- rho:ρ的精度。
- theta:θ的精度。
- threshold:阈值,得票数高于该值的线才被认为是线,由于投票数取决于线上的点数,所以它代表了应该被检测到的线的最小点数。

显示结果

cv2.imshow("Hough Transform Result", img)
cv2.waitKey(0)
cv2.destroyAllWindows()

效果:
效果

相关推荐

  1. 基于opencv的直线检测(python&C++)

    2024-04-01 05:26:04       39 阅读
  2. 线特征_LSD直线检测算法和LBD直线描述子

    2024-04-01 05:26:04       37 阅读
  3. 基于MATLAB的霍夫变换直线检测

    2024-04-01 05:26:04       41 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-01 05:26:04       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-01 05:26:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-01 05:26:04       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-01 05:26:04       20 阅读

热门阅读

  1. 算法打卡day22

    2024-04-01 05:26:04       16 阅读
  2. qtcreator msvc编译器 链接外部库的方式

    2024-04-01 05:26:04       17 阅读
  3. MATLAB实现在LSB低三位嵌入图像

    2024-04-01 05:26:04       17 阅读
  4. 小程序归类及适合企业运用

    2024-04-01 05:26:04       16 阅读
  5. Web框架开发-Django信号

    2024-04-01 05:26:04       13 阅读
  6. 2023年C++语言B组蓝桥杯的三道题解【题解整合】

    2024-04-01 05:26:04       15 阅读
  7. 探索ChatGPT在学术论文写作中的应用方法

    2024-04-01 05:26:04       16 阅读
  8. ChatGPT:改变你的学术写作方式

    2024-04-01 05:26:04       21 阅读
  9. 100266. 交替子数组计数

    2024-04-01 05:26:04       17 阅读
  10. 蓝桥杯该如何准备

    2024-04-01 05:26:04       23 阅读
  11. 【Redis】多机部署Redis-sentinel

    2024-04-01 05:26:04       17 阅读
  12. Web框架开发-Django-extra过滤

    2024-04-01 05:26:04       17 阅读
  13. PostCSS深入解析:安装、配置与高效使用

    2024-04-01 05:26:04       24 阅读