OpenCV | 霍夫变换检测直线

上次写的不好,这次重写一个霍夫变化的框架,里面包括灰度转换、滤波

canny边缘检测、霍夫变换等......

原始图像

python 复制代码
import cv2
import numpy as np
import matplotlib.pyplot as plt#Matplotlib是RGB
%matplotlib inline 

def detect_parking_lines(image_path):
    # 读取图像
    img = cv2.imread(image_path)

    # 灰度转换
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

    # 高斯滤波
    gray = cv2.GaussianBlur(gray, (5, 5), 0)

    # Canny 边缘检测
    edges = cv2.Canny(gray, 50, 150)

    # Hough 变换检测直线
    lines = cv2.HoughLines(edges, 1, np.pi / 180, 130)

    # 绘制检测到的直线
    if lines is not None:
        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, 255, 0), 2)

    # 显示结果
    cv2.imshow('Detected Parking Lines', img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()

# 调用函数进行车位线检测
detect_parking_lines('chessboard.jpg')

识别后图像:

相关推荐
名字不好奇1 分钟前
大模型的思考模式:它真的在“想“吗?
人工智能·算法
weixin_468466853 分钟前
大语言模型快速部署与调用指南
人工智能·ai·自然语言处理·大模型·云计算·大语言模型·本地化部署
LuminWave5 分钟前
多维场景落地,3D激光雷达成机器人产业核心感知基石
人工智能·3d·机器人
时光飞逝的日子7 分钟前
从 Copilot 到智能体:2026 年 AI 编程工具全栈测评
人工智能·copilot
jiayong2312 分钟前
harness与hermes-agent的区别
人工智能·ai·智能体·harness·hermes-agent
xiaoxiaoxiaolll13 分钟前
机器学习智能水泥基复合材料
人工智能
星辰AI14 分钟前
AI 应用微服务架构设计:从单体到分布式的演进
人工智能·ai·语言模型
ftpeak15 分钟前
RTP-LLM:阿里巴巴开源的大模型推理加速引擎详解
人工智能·ai·开源·ai编程·ai开发
ZhengEnCi16 分钟前
09aaaba-LayerNorm中心化操作是什么?
人工智能
前沿科技说i17 分钟前
2026年AI大模型API中转站:主流服务商性能、成本与适配能力
人工智能