OpenCV半小时掌握基本操作之直线检测

作者:我是小白呀 时间:2023-12-27 12:31:29 

【OpenCV】 ⚠️高手勿入! 半小时学会基本操作 ⚠️ 直线检测

概述

OpenCV 是一个跨平台的计算机视觉库, 支持多语言, 功能强大. 今天小白就带大家一起携手走进 OpenCV 的世界. (第 13 课)

OpenCV半小时掌握基本操作之直线检测

霍夫直线变换

霍夫变换 (Hough Line Transform) 是图像处理中的一种特征提取技术. 通过平面空间到极值坐标空间的转换, 可以帮助我们实现直线检测. 如图:

OpenCV半小时掌握基本操作之直线检测

原理详解

当我们把直线 y = kx + b 画在指标坐标系上, 如下图. 我们再从原点引线段到直线上的任一点.

OpenCV半小时掌握基本操作之直线检测

我们可以得到这条线段与 x 轴的夹角为 θ, 距离是 r. 对于直线上的任一点 (x0, y0), 我们可以得到公式:

OpenCV半小时掌握基本操作之直线检测

代码实战

HoughLines

格式:


cv2.HoughLines(image, rho, theta, threshold, lines=None, srn=None, stn=None, min_theta=None, max_theta=None)

参数:

  • image: 输入图像

  • rho: 线性搜索半径步长, 以像素为单位

  • theta: 线性搜索步长, 以弧度为单位

  • threshold: 累计阈值

例子:


import numpy as np
import cv2
from matplotlib import pyplot as plt

# 读取图片
image = cv2.imread("sudoku.jpg")
image_copy = image.copy()

# 转换成灰度图
image_gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 边缘检测, Sobel算子大小为3
edges = cv2.Canny(image_gray, 170, 220, apertureSize=3)

# 霍夫曼直线检测
lines = cv2.HoughLines(edges, 1, np.pi / 180, 250)

# 遍历
for line in lines:
   # 获取rho和theta
   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(image_copy, (x1, y1), (x2, y2), (0, 0, 255), thickness=5)

# 图片展示
f, ax = plt.subplots(2, 2, figsize=(12, 12))

# 子图
ax[0, 0].imshow(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
ax[0, 1].imshow(image_gray, "gray")
ax[1, 0].imshow(edges, "gray")
ax[1, 1].imshow(cv2.cvtColor(image_copy, cv2.COLOR_BGR2RGB))

# 标题
ax[0, 0].set_title("original")
ax[0, 1].set_title("image gray")
ax[1, 0].set_title("image edge")
ax[1, 1].set_title("image line")

plt.show()

输出结果:

OpenCV半小时掌握基本操作之直线检测

OpenCV半小时掌握基本操作之直线检测

HoughLinesP

此函数在 HoughLines 的基础上末尾加了一个代表概率 (Probabilistic) 的 P, 表明它可以采用累计概率霍夫变换, 来找出二值图像中的直线.

格式:


HoughLinesP(image, rho, theta, threshold, lines=None, minLineLength=None, maxLineGap=None)

参数:

  • image: 输入图像

  • rho: 线性搜索半径步长, 以像素为单位

  • theta: 线性搜索步长, 以弧度为单位

  • threshold: 累计阈值

  • minLineLength: 最短直线长度

  • maxLineGap: 最大孔隙距离

例子:


import numpy as np
import cv2
from matplotlib import pyplot as plt

# 读取图片
image = cv2.imread("sudoku.jpg")
image_copy = image.copy()

# 转换成灰度图
image_gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 边缘检测, Sobel算子大小为3
edges = cv2.Canny(image_gray, 170, 220, apertureSize=3)

# 霍夫曼直线检测
lines = cv2.HoughLinesP(edges, 1, np.pi / 180, 100, minLineLength=100, maxLineGap=10)

# 遍历
for line in lines:

# 获取坐标
   x1, y1, x2, y2 = line[0]
   cv2.line(image_copy, (x1, y1), (x2, y2), (0, 0, 255), thickness=5)

# 图片展示
f, ax = plt.subplots(2, 2, figsize=(12, 12))

# 子图
ax[0, 0].imshow(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
ax[0, 1].imshow(image_gray, "gray")
ax[1, 0].imshow(edges, "gray")
ax[1, 1].imshow(cv2.cvtColor(image_copy, cv2.COLOR_BGR2RGB))

# 标题
ax[0, 0].set_title("original")
ax[0, 1].set_title("image gray")
ax[1, 0].set_title("image edge")
ax[1, 1].set_title("image line")

plt.show()

输出结果:

OpenCV半小时掌握基本操作之直线检测

OpenCV半小时掌握基本操作之直线检测

来源:https://blog.csdn.net/weixin_46274168/article/details/119338656

标签:OpenCV,直线检测,python
0
投稿

猜你喜欢

  • ThinkPHP模板判断输出Empty标签用法详解

    2023-11-14 20:46:54
  • 用Dreamweaver实现Real与网页结合

    2010-07-13 12:11:00
  • python实现隐马尔科夫模型HMM

    2023-05-05 13:33:57
  • 链接与文本标签们

    2008-04-04 18:07:00
  • Go库text与template包使用示例详解

    2024-04-26 17:21:16
  • python机器学习算法与数据降维分析详解

    2023-09-20 19:40:27
  • Python对数据进行插值和下采样的方法

    2022-06-02 03:36:41
  • numpy的Fancy Indexing和array比较详解

    2022-05-12 23:31:46
  • go语言的变量定义示例详解

    2024-04-27 15:26:03
  • python 删除指定时间间隔之前的文件实例

    2023-07-19 17:58:38
  • Mysql设置主键自动增长起始值的方案总结

    2024-01-16 18:49:23
  • 让MYSQL彻底支持中文

    2008-12-24 16:23:00
  • Python使用re模块正则提取字符串中括号内的内容示例

    2022-06-15 14:20:04
  • javascript 三 级下拉选择菜单Levels对象

    2023-09-05 03:28:48
  • 跟老齐学Python之折腾一下目录

    2021-10-07 03:07:52
  • Go语言实现的web爬虫实例

    2023-07-21 02:35:57
  • 浅谈Python中chr、unichr、ord字符函数之间的对比

    2022-02-27 16:02:58
  • Python-openCV读RGB通道图实例

    2023-01-26 12:28:26
  • MYSQL教程:数据列类型与查询效率

    2009-02-27 15:37:00
  • Python for Informatics 第11章 正则表达式(一)

    2021-01-27 06:43:43
  • asp之家 网络编程 m.aspxhome.com