【Opencv】Hough变换找直线和圆

2024-08-27 19:08
文章标签 opencv 直线 变换 hough

本文主要是介绍【Opencv】Hough变换找直线和圆,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

题目

解决方法

完整代码

Hough参数详解

总结

参考


题目

用霍夫变换找出图像中的直线和圆(用彩色直线和圆标记在原图上)。要求有代码,有注释,有过程、有结果

 

解决方法

# -*- coding: UTF-8 -*-
import cv2
import numpy as np
# 1.加载图片,转为二值图
img = cv2.imread('image.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)  # 由于Canny只能处理灰度图,所以将读取的图像转成灰度图。
cv2.imshow('gray', gray)

gray = cv2.GaussianBlur(gray, (3, 3), 0)  # 用高斯平滑处理原图像降噪。
cv2.imshow('Gaussian smoothing', gray)

edges = cv2.Canny(gray, 70, 220)
cv2.imshow('edges', edges)


 

# 2.1.霍夫直线变换
lines = cv2.HoughLinesP(edges, 1, np.pi / 180, 25, minLineLength=19, maxLineGap=17)
'''
image: 必须是二值图像,推荐使用canny边缘检测的结果图像
rho: 线段以像素为单位的距离精度,推荐用1.0
theta: 线段以弧度为单位的角度精度,推荐用numpy.pi/180
minLineLength:表示直线长度的阈值,超过设定阈值才被检测出线段,值越大,基本上意味着检出的线段越长,检出的线段个数越少
MaxLineGap:同一方向上两条线段判定为一条线段的最大允许间隔(断裂),小于了设定值,则把两条线段当成一条线段返回值为直线的起点和终点。
'''# 2.2.霍夫圆变换
circles = cv2.HoughCircles(edges, cv2.HOUGH_GRADIENT, 1, 100, param2=30)
circles = np.int0(np.around(circles))# 3.将检测到的画出来
lines1 = lines[:, 0, :]  # 提取为二维
for x1, y1, x2, y2 in lines1[:]:cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2)for i in circles[0, :]:cv2.circle(img, (i[0], i[1]), i[2], (0, 0, 255), 2)  # 画出外圆# cv2.circle(img, (i[0], i[1]), 2, (0, 255, 0), 3)  # 画出圆心cv2.imshow('Result', img)
cv2.waitKey(0)

完整代码

# -*- coding: UTF-8 -*-
import cv2
import numpy as np# 1.加载图片,转为二值图
img = cv2.imread('image.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)  # 由于Canny只能处理灰度图,所以将读取的图像转成灰度图。
cv2.imshow('gray', gray)
gray = cv2.GaussianBlur(gray, (3, 3), 0)  # 用高斯平滑处理原图像降噪。
cv2.imshow('Gaussian smoothing', gray)edges = cv2.Canny(gray, 70, 220)
cv2.imshow('edges', edges)# 2.1.霍夫直线变换
lines = cv2.HoughLinesP(edges, 1, np.pi / 180, 25, minLineLength=19, maxLineGap=17)
'''
image: 必须是二值图像,推荐使用canny边缘检测的结果图像
rho: 线段以像素为单位的距离精度,推荐用1.0 
theta: 线段以弧度为单位的角度精度,推荐用numpy.pi/180 
minLineLength:表示直线长度的阈值,超过设定阈值才被检测出线段,值越大,基本上意味着检出的线段越长,检出的线段个数越少
MaxLineGap:同一方向上两条线段判定为一条线段的最大允许间隔(断裂),小于了设定值,则把两条线段当成一条线段
返回值为直线的起点和终点。
'''# 2.2.霍夫圆变换
circles = cv2.HoughCircles(edges, cv2.HOUGH_GRADIENT, 1, 100, param2=30)
circles = np.int0(np.around(circles))# 3.将检测到的画出来
lines1 = lines[:, 0, :]  # 提取为二维
for x1, y1, x2, y2 in lines1[:]:cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2)for i in circles[0, :]:cv2.circle(img, (i[0], i[1]), i[2], (0, 0, 255), 2)  # 画出外圆# cv2.circle(img, (i[0], i[1]), 2, (0, 255, 0), 3)  # 画出圆心cv2.imshow('Result', img)
cv2.waitKey(0)

Hough参数详解

cv2.HoughCircles(image,method,dp,minDist[, circles[,param1, param2[,minRadius[,maxRadius]]]]])

其返回N个圆的信息储存在1×N×的ndarray。

image 不用多说,输入矩阵
method cv2.HOUGH_GRADIENT 也就是霍夫圆检测,梯度法
dp 计数器的分辨率图像像素分辨率与参数空间分辨率的比值(官方文档上写的是图像分辨率与累加器分辨率的比值,它把参数空间认为是一个累加器,毕竟里面存储的都是经过的像素点的数量),dp=1,则参数空间与图像像素空间(分辨率)一样大,dp=2,参数空间的分辨率只有像素空间的一半大
minDist 圆心之间最小距离,如果距离太小,会产生很多相交的圆,如果距离太大,则会漏掉正确的圆
param1 canny检测的双阈值中的高阈值,低阈值是它的一半(如果你的圆找不到,可以将该参数变小点)
param2 最小投票数(基于圆心的投票数)
minRadius 需要检测院的最小半径
maxRadius 需要检测院的最大半径

总结

我对hough变换的理解:你的圆一定要非常明显,通过图像处理的方式将圆的边界变得足够清晰,然后使用hough变换才有效。

参考

https://blog.csdn.net/zuliang001/article/details/81607548 

https://blog.csdn.net/dz4543/article/details/80699431 

这篇关于【Opencv】Hough变换找直线和圆的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112518

相关文章

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

在PyCharm中安装PyTorch、torchvision和OpenCV详解

《在PyCharm中安装PyTorch、torchvision和OpenCV详解》:本文主要介绍在PyCharm中安装PyTorch、torchvision和OpenCV方式,具有很好的参考价值,... 目录PyCharm安装PyTorch、torchvision和OpenCV安装python安装PyTor