openCV霍夫变换

本文介绍了一种使用霍夫变换检测图像中直线的方法,并通过Python的OpenCV库实现了该算法。具体步骤包括读取图像、转换为灰度图、边缘检测及应用霍夫变换找出图像内的直线。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

霍夫变换

© Fu Xianjun. All Rights Reserved
素材
在这里插入图片描述
代码
import cv2
import numpy as np

img = cv2.imread(“shape.png”)
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
edge = cv2.Canny(gray,50,150)
lines = cv2.HoughLines(edge,1,np.pi/180,50)

for line in lines:
rho, theta = line[0]
a = np.cos(theta)
b = np.sin(theta)
x0 = rho *a
y0 = rho *b
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,255,0),2)

cv2.imshow(“np”,img)
cv2.imshow(“gray”,gray)
cv2.imshow(“edges”,edge)
cv2.waitKey(0)
cv2.destroyAllWindows()
显示效果

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值