C++opencv获取轮廓中心
时间: 2023-07-04 19:30:32 浏览: 130
在C++中使用OpenCV库获取轮廓中心的方法如下:
1. 首先读取图像并进行预处理,例如二值化、平滑等。
2. 使用findContours函数找到图像中的轮廓并存储在一个vector容器中。
3. 对每个轮廓,使用moments函数计算其矩,并根据矩计算出轮廓中心坐标。
下面是一个示例代码:
```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++)
{
// 计算轮廓的矩
Moments mu = moments(contours[i], false);
// 计算轮廓中心坐标
Point2f center(mu.m10 / mu.m00, mu.m01 / mu.m00);
// 绘制轮廓中心
circle(drawing, center, 5, Scalar(0, 0, 255), -1);
}
imshow("result", drawing);
waitKey(0);
return 0;
}
```
运行程序后,会显示原始图像和轮廓中心的绘制结果。
阅读全文