C++opencv轮廓最小外接圆
时间: 2023-07-07 15:26:43 浏览: 153
在C++中使用OpenCV库进行轮廓最小外接圆的计算,可以按照以下步骤进行:
1. 首先读取图像并进行预处理,例如二值化、平滑等。
2. 使用findContours函数找到图像中的轮廓并存储在一个vector容器中。
3. 对每个轮廓,使用minEnclosingCircle函数计算最小外接圆的圆心和半径。
4. 可以使用circle函数绘制出最小外接圆。
下面是一个示例代码:
```c++
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace std;
using namespace cv;
int main()
{
// 读取图像并进行预处理
Mat src = imread("test.jpg");
Mat gray, binary;
cvtColor(src, gray, COLOR_BGR2GRAY);
threshold(gray, binary, 0, 255, THRESH_BINARY | THRESH_OTSU);
imshow("binary", binary);
// 查找轮廓并存储
vector<vector<Point> > contours;
vector<Vec4i> hierarchy;
findContours(binary, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point());
// 对每个轮廓计算最小外接圆
Mat drawing = Mat::zeros(binary.size(), CV_8UC3);
for (size_t i = 0; i < contours.size(); i++)
{
Point2f center;
float radius;
minEnclosingCircle(contours[i], center, radius);
// 绘制最小外接圆
circle(drawing, center, (int)radius, Scalar(0, 0, 255), 2);
}
imshow("result", drawing);
waitKey(0);
return 0;
}
```
运行程序后,会显示原始图像和最小外接圆的绘制结果。
阅读全文