OpenCV之霍夫圆变换

本文介绍了一种基于霍夫梯度法的圆检测技术,并通过OpenCV中的HoughCircles函数实现圆的检测。该文详细展示了从图像读取到最终绘制检测到的圆的整个过程,包括图像预处理、灰度转换、高斯模糊等步骤。

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

霍夫圆变换的基本原理

 

霍夫梯度法的原理

 霍夫梯度法的缺点

霍夫圆变换:HoughCircles()函数

 

代码 


#include <iostream>
#include <opencv2/core.hpp>
#include <opencv2/highgui.hpp>
#include <opencv2/imgproc.hpp>
#include <opencv2/videoio.hpp>
#include <opencv2/video.hpp>
 
using namespace cv;
using namespace std;


int main(int argc, char** argv)
{
	//1.载入原图, Mat变量定义
	Mat srcImage = imread("my.jpg");
	Mat midImage, dstImage;

	//2.显示原始图
	imshow("原始图", srcImage);

	//3.转为灰度图并进行图像平滑
	cvtColor(srcImage, midImage, COLOR_BGR2GRAY);//转化边缘检测后的图为灰度图
	GaussianBlur(midImage, midImage, Size(9, 9), 2, 2);

	//4.进行霍夫圆变换
	vector<Vec3f> circles;
	HoughCircles(midImage, circles, HOUGH_GRADIENT, 1.5, 10, 200, 100, 0, 0);

	//5.依次在途中绘制出圆
	for (size_t i = 0; i < circles.size(); i++)
	{
		//参数定义
		Point center(cvRound(circles[i][0]), cvRound(circles[i][1]));
		int radius = cvRound(circles[i][2]);
		//绘制圆心
		circle(srcImage, center, 3, Scalar(0, 255, 0), -1, 8, 0);
		//绘制圆轮廓
		circle(srcImage, center, radius, Scalar(155, 20, 255), 3, 8, 0);
	}
	
	//6.显示效果图
	imshow("效果图", srcImage);
	waitKey(0);
	return 0;
}

效果

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值