Python Opencv实践 - 霍夫线检测(Hough Lines)

import cv2 as cv
import numpy as np
import matplotlib.pyplot as plt
import random

img = cv.imread("../SampleImages/GreenBoard.jpg")
print(img.shape)
plt.imshow(img[:,:,::-1])

#将图像转为二值图
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
plt.imshow(gray, cmap=plt.cm.gray)

#使用Canny边缘检测
edges = cv.Canny(gray, 50, 150)
plt.imshow(edges, cmap=plt.cm.gray)

#霍夫线检测
#cv.HoughLines(image, rho, theta, threshold, lines=None, minLineLength=None, maxLineGap=None) 
#image: 必须是二值图像,推荐使用canny边缘检测的结果图像; 
#rho: 线段以像素为单位的距离精度,double类型的,推荐用1.0 
#theta: 线段以弧度为单位的角度精度,推荐用numpy.pi/180 
#threshod: 累加平面的阈值参数,int类型,超过设定阈值才被检测出线段,值越大,基本上意味着检出的线段越长,检出的线段个数越少。根据情况推荐先用100试试
#lines:这个参数的意义未知,发现不同的lines对结果没影响,但是不要忽略了它的存在 
#minLineLength:线段以像素为单位的最小长度,根据应用场景设置 
#maxLineGap:同一方向上两条线段判定为一条线段的最大允许间隔(断裂),超过了设定值,则把两条线段当成一条线段,值越大,允许线段上的断裂越大,越有可能检出潜在的直线段
#参考资料:https://blog.csdn.net/dcrmg/article/details/78880046
lines = cv.HoughLines(edges, 0.8, np.pi / 180, 150)

#绘制霍夫线检测结果
for line in lines:
    rho,theta = line[0]
    a = np.cos(theta)
    b = np.sin(theta)
    x0 = a * rho
    y0 = b * rho
    x1 = int(x0 + 1000 * (-b))
    y1 = int(y0 + 1000 * a)
    x2 = int(x0 - 1000 * (-b))
    y2 = int(y0 - 1000 * a)
    cv.line(img, (x1,y1), (x2,y2), (0,0,255))

plt.imshow(img[:,:,::-1])

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
霍夫线变换(Hough Line Transform)是一种图像处理技术,用于检测图像中的直线。在 OpenCV 中,可以使用 cv2.HoughLines() 函数实现霍夫线变换。 下面是一个简单的 Python 示例,演示如何使用霍夫线变换检测一张图像中的直线: ```python import cv2 import numpy as np # 读取图像 img = cv2.imread('image.jpg') # 将图像转换为灰度图 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 提取边缘 edges = cv2.Canny(gray, 50, 150, apertureSize=3) # 进行霍夫线变换 lines = cv2.HoughLines(edges, 1, np.pi/180, 200) # 绘制检测到的直线 for line in lines: rho, theta = line[0] a = np.cos(theta) b = np.sin(theta) x0 = a * rho y0 = b * rho x1 = int(x0 + 1000 * (-b)) y1 = int(y0 + 1000 * (a)) x2 = int(x0 - 1000 * (-b)) y2 = int(y0 - 1000 * (a)) cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2) # 显示结果 cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在上面的示例中,首先读取一张图像,并将其转换为灰度图。然后使用 Canny 边缘检测算法提取图像的边缘。接下来,使用 cv2.HoughLines() 函数进行霍夫线变换,检测图像中的直线。最后,使用 cv2.line() 函数绘制检测到的直线,并在窗口中显示结果。 需要注意的是,cv2.HoughLines() 函数的参数需要根据具体情况进行调整,比如第二个参数表示距离分辨率(即 Hough 空间中的距离单位),第三个参数表示角度分辨率(即 Hough 空间中的角度单位),第四个参数表示阈值,用于控制检测到的直线数量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

亦枫Leonlew

希望这篇文章能帮到你

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值