【OpenCV】图像变换(四-2)霍夫变换圆检测
2015-04-27 15:12
239 查看
在上篇的博文中,我们重点讨论了霍夫变换的线段检测的数学原理,以及怎样在OpenCV中去实现线段的检测。在这篇博文中,关于圆的检测的数学理论,我们不做重点介绍。我们将简要介绍下OpenCV中自带的基于霍夫变换的圆检测函数cvHoughCircles()。
下面给出个程序的示例:
CvSeq* cvHoughCircles( CvArr* image,//8位的图像,不过不需要是二值图像,可以是灰度图 void* circle_storage,//存储结果的存储器 int method,//这个参数必须设置为CV_HOUGH_GRADIENT double dp,//累加器图像的分辨率,可设置为1或2,但是不能比1小 double min_dist,//让算法能明显区分的两个不同圆之间的最小距离 double param1=100,//边缘阈值 double param2=300,//累加器阈值 int min_radius=0, int max_radius=0//发现圆半径的最小值和最大值 )
下面给出个程序的示例:
#include<iostream> #include<opencv2/opencv.hpp> using namespace std; int main() { const char *pSrcWindow = "原图"; const char *pDstWindow = "Hough圆检测图"; IplImage *pSrcImage = cvLoadImage("1.png", CV_LOAD_IMAGE_UNCHANGED); IplImage *pGrayImage = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 1); //转化为灰度图 cvCvtColor(pSrcImage, pGrayImage, CV_BGR2GRAY); //构建个存储器,为后面的函数cvHoughCircles()传参 CvMemStorage *circle_storage = cvCreateMemStorage(); double min_dst = pGrayImage->height / 10; //调用cvHoughCircles()函数,函数返回的是个序列 CvSeq* results = cvHoughCircles(pGrayImage, circle_storage, CV_HOUGH_GRADIENT, 1, min_dst); IplImage *pColorImage = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 3); cvCvtColor(pGrayImage, pColorImage, CV_GRAY2BGR); //将函数cvHoughCircles()检测得到的结果,遍历输出,并且画图 for (int i = 0; i < results->total; ++i) { float *p = (float*)cvGetSeqElem(results, i); cvCircle(pColorImage, cvPoint(cvRound(p[0]), cvRound(p[1])), cvRound(p[2]), CV_RGB(255, 0, 0), 2); } cvNamedWindow(pSrcWindow, CV_WINDOW_AUTOSIZE); cvNamedWindow(pDstWindow, CV_WINDOW_AUTOSIZE); cvShowImage(pSrcWindow, pSrcImage); cvShowImage(pDstWindow, pColorImage); cvWaitKey(); cvReleaseImage(&pSrcImage); cvReleaseImage(&pGrayImage); cvReleaseImage(&pColorImage); cvReleaseMemStorage(&circle_storage); cvDestroyWindow(pSrcWindow); cvDestroyWindow(pDstWindow); return 0; }
相关文章推荐
- 【OpenCV】图像变换(四-1)-霍夫变换线段检测
- (openCV)Canny算子加霍夫变换检测直线
- Opencv学习笔记-----霍夫变换直线检测及原理理解
- 通过圆的颜色并结合霍夫变换检测目标圆的OpenCV代码
- 霍夫变换直线检测houghlines及opencv的实现分析
- opencv-霍夫变换 检测直线
- OpenCV的霍夫变换(Hough Transform)直线检测
- 基于opencv利用霍夫变换实现圆形物体的检测
- 在OpenCV下利用霍夫变换进行直线检测和圆检测
- OpenCV的霍夫变换(Hough Transform)圆检测
- 霍夫变换直线检测及opencv实现
- opencv 霍夫变换检测直线
- opencv 图像处理 形态学操作 腐蚀 膨胀 开闭运算 阈值二值化 图像卷积 图像金字塔 Sobel算子 Laplacian 算子 candy边缘检测 霍夫变换 直方图
- OpenCV 霍夫变换直线检测(SHT、MSHT和PPHT)
- 【OpenCV】图像变换(二)边缘检测:梯度算子、Sobel算子和Laplace算子
- 霍夫变换检测直线的公式推导以及基于opencv的源代码分析并实例实现
- OpenCV-Python教程(9)(10)(11): 使用霍夫变换检测直线 直方图均衡化 轮廓检测
- linux+Qt+Opencv实现采集摄像头采集,截图,边缘检测,霍夫变换
- 霍夫变换检测直线及openCV代码
- opencv 霍夫变换检测圆cvHoughCircles