【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优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

POJ1269 判断2条直线的位置关系

题目大意:给两个点能够确定一条直线,题目给出两条直线(由4个点确定),要求判断出这两条直线的关系:平行,同线,相交。如果相交还要求出交点坐标。 解题思路: 先判断两条直线p1p2, q1q2是否共线, 如果不是,再判断 直线 是否平行, 如果还不是, 则两直线相交。  判断共线:  p1p2q1 共线 且 p1p2q2 共线 ,共线用叉乘为 0  来判断,  判断 平行:  p1p

opencv 滚动条

参数介绍:createTrackbar( trackbarname , "hello" , &alpha_slider ,alpha_max ,  on_trackbar )  ;在标签中显示的文字(提示滑动条的用途) TrackbarName创建的滑动条要放置窗体的名字 “hello”滑动条的取值范围从 0 到 alpha_max (最小值只能为 zero).滑动后的值存放在

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

树莓派5_opencv笔记27:Opencv录制视频(无声音)

今日继续学习树莓派5 8G:(Raspberry Pi,简称RPi或RasPi)  本人所用树莓派5 装载的系统与版本如下:  版本可用命令 (lsb_release -a) 查询: Opencv 与 python 版本如下: 今天就水一篇文章,用树莓派摄像头,Opencv录制一段视频保存在指定目录... 文章提供测试代码讲解,整体代码贴出、测试效果图 目录 阶段一:录制一段

Verybot之OpenCV应用三:色标跟踪

下面的这个应用主要完成的是Verybot跟踪色标的功能,识别部分还是居于OpenCV编写,色标跟踪一般需要将图像的颜色模式进行转换,将RGB转换为HSV,因为对HSV格式下的图像进行识别时受光线的影响比较小,但是也有采用RGB模式来进行识别的情况,这种情况一般光线条件比较固定,背景跟识别物在颜色上很容易区分出来。         下面这个程序的流程大致是这样的:

Verybot之OpenCV应用二:霍夫变换查找圆

其实我是想通过这个程序来测试一下,OpenCV在Verybot上跑得怎么样,霍夫变换的原理就不多说了,下面是程序: #include "cv.h"#include "highgui.h"#include "stdio.h"int main(int argc, char** argv){cvNamedWindow("vedio",0);CvCapture* capture;i

Verybot之OpenCV应用一:安装与图像采集测试

在Verybot上安装OpenCV是很简单的,只需要执行:         sudo apt-get update         sudo apt-get install libopencv-dev         sudo apt-get install python-opencv         下面就对安装好的OpenCV进行一下测试,编写一个通过USB摄像头采

虚拟机ubuntu配置opencv和opencv_contrib

前期准备  1.下载opencv和opencv_contrib源码 opencv-4.6.0:https://opencv.org/releases/ opencv_contrib-4.6.0:https://github.com/opencv/opencv_contrib 在ubuntu直接下载或者在window上下好传到虚拟机里都可以 自己找个地方把他们解压,个人习惯在home下新建一