在学习opencv的过程中,我发现用霍夫圆变换去检测圆的效果并不理想,对不同的图像,需要设置不同的参数,才能得到较好的效果。于是我就想到了利用滑动条来改变参数,这样对不同的图片,只需通过改变滑动条,都可以检测出拟合度较好的圆。
以下为代码:
#include<opencv2/opencv.hpp>
#include<opencv2/imgproc/imgproc.hpp>
using namespace cv;
using namespace std;
Mat srcImage=imread("test88.jpg");//读取图像
Mat midImage;//定义临时变量
/*霍夫圆变换参数声明*/
double dp=1.5;//累加器图像的反比分辨率
double min_dist=0.1;//检测到圆心之间的最小距离
int param_1=30;//Canny边缘函数的高阈值
int param_2=20;//圆心检测阈值
int min_radius=0,max_radius=100;//能检测到的最小最大圆半径
void on_Trackbar(int ,void*)
{
/*霍夫圆变换*/
vector<Vec3f> circles;//声明一个向量,保存检测出的圆的圆心坐标和半径
HoughCircles(midImage, circles,CV_HOUGH_GRADIENT, dp, min_dist, param_1, param_2, min_radius, max_radius);
/*把图像复制到srcImage2,让每次回调都重新画图*/
Mat srcImage2;
srcImage.copyTo(srcImage2);
/*依次在图中绘制出圆*/
for (size_t i = 0; i