opencv c++获取最小轮廓以及中心点坐标代码

时间: 2023-03-10 09:35:30 浏览: 202
使用OpenCV C ++,可以使用findContours函数来获取最小轮廓,minAreaRect函数来获取最小轴对齐矩形,moments函数来获取中心点坐标。例如:// 获取最小轮廓 vector<vector<Point> > contours; findContours(src, contours, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE);// 获取最小轴对齐矩形 RotatedRect rect = minAreaRect(contours[0]);// 获取中心点坐标 Moments m = moments(contours[0], false); Point2f center = Point2f(m.m10 / m.m00, m.m01 / m.m00);
相关问题

OpenCV C++ 轮廓提取坐标和中心点的代码

### 回答1: 以下是提取轮廓坐标和中心点的代码示例: ``` #include <opencv2/opencv.hpp> #include <iostream> using namespace cv; using namespace std; int main() { Mat src = imread("image.jpg", IMREAD_GRAYSCALE); Mat binary; threshold(src, binary, 100, 255, THRESH_BINARY); vector<vector<Point>> contours; vector<Vec4i> hierarchy; findContours(binary, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE); for (size_t i = ; i < contours.size(); i++) { // 计算轮廓的中心点 Moments mu = moments(contours[i]); Point2f center(mu.m10 / mu.m00, mu.m01 / mu.m00); cout << "Contour " << i << " center: " << center << endl; // 输出轮廓的坐标 for (size_t j = ; j < contours[i].size(); j++) { cout << "Contour " << i << " point " << j << ": " << contours[i][j] << endl; } } return ; } ``` 这段代码可以读取一张灰度图像,提取其轮廓,并输出每个轮廓的坐标和中心点。 ### 回答2: 以下是使用OpenCV C进行轮廓提取,并获取轮廓坐标和中心点的代码: ```c #include <opencv2/opencv.hpp> using namespace cv; int main() { // 读取图像 Mat image = imread("example.jpg", IMREAD_GRAYSCALE); // 阈值化图像 threshold(image, image, 128, 255, THRESH_BINARY); // 查找轮廓 std::vector<std::vector<Point>> contours; findContours(image, contours, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE); // 遍历每个轮廓 for (int i = 0; i < contours.size(); i++) { // 绘制轮廓 drawContours(image, contours, i, Scalar(255), 2); // 计算轮廓的中心点 Moments m = moments(contours[i]); Point center(m.m10 / m.m00, m.m01 / m.m00); // 输出轮廓坐标和中心点 printf("Contour %d:\n", i); for (int j = 0; j < contours[i].size(); j++) { printf("Point %d: (%d, %d)\n", j, contours[i][j].x, contours[i][j].y); } printf("Center: (%d, %d)\n", center.x, center.y); } // 显示结果 imshow("Contours", image); waitKey(0); return 0; } ``` 请注意,您需要将图像文件名更改为实际使用的图像文件,并根据需要进行其他适应性更改。此代码可用于提取图像中的轮廓,然后计算每个轮廓的中心点,并打印出轮廓坐标和中心点的值。 ### 回答3: 确定OpenCV版本: 首先,需要确定使用的OpenCV版本是C++还是C。如果是C++版本,可以使用cv::findContours函数来提取轮廓坐标和中心点。 C++代码示例: ```cpp #include <opencv2/opencv.hpp> #include <iostream> int main() { // 加载图像 cv::Mat image = cv::imread("input.png", cv::IMREAD_GRAYSCALE); // 二值化图像 cv::Mat binaryImage; cv::threshold(image, binaryImage, 128, 255, cv::THRESH_BINARY); // 寻找轮廓 std::vector<std::vector<cv::Point>> contours; std::vector<cv::Vec4i> hierarchy; cv::findContours(binaryImage, contours, hierarchy, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_SIMPLE); // 遍历每个轮廓 for (int i = 0; i < contours.size(); i++) { // 计算轮廓中心点坐标 cv::Moments moments = cv::moments(contours[i]); cv::Point center(moments.m10 / moments.m00, moments.m01 / moments.m00); // 打印轮廓坐标和中心点坐标 std::cout << "Contour #" << i << std::endl; for (int j = 0; j < contours[i].size(); j++) { std::cout << "Coordinate: (" << contours[i][j].x << ", " << contours[i][j].y << ")" << std::endl; } std::cout << "Center: (" << center.x << ", " << center.y << ")" << std::endl; } return 0; } ``` 以上示例代码假设输入的图像是灰度图像,二值化阈值为128,且只提取外部轮廓(RETR_EXTERNAL)。 如果使用的是C版本的OpenCV,可以参考以下代码进行相应修改: C代码示例: ```c #include <opencv2/opencv.hpp> #include <opencv2/highgui/highgui_c.h> #include <stdio.h> int main() { // 加载图像 IplImage* image = cvLoadImage("input.png", CV_LOAD_IMAGE_GRAYSCALE); CvMat* binaryImage = cvCreateMat(image->height, image->width, CV_8UC1); // 二值化图像 cvThreshold(image, binaryImage, 128, 255, CV_THRESH_BINARY); // 寻找轮廓 CvMemStorage* storage = cvCreateMemStorage(0); CvSeq* contours = NULL; cvFindContours(binaryImage, storage, &contours, sizeof(CvContour), CV_RETR_EXTERNAL, CV_CHAIN_APPROX_SIMPLE); // 遍历每个轮廓 int i = 0; for (CvSeq* contour = contours; contour != NULL; contour = contour->h_next) { CvMoments moments; cvMoments(contour, &moments); int cX = (int)(moments.m10 / moments.m00); int cY = (int)(moments.m01 / moments.m00); printf("Contour #%d\n", i++); for (int j = 0; j < contour->total; j++) { CvPoint* pt = (CvPoint*)cvGetSeqElem(contour, j); printf("Coordinate: (%d, %d)\n", pt->x, pt->y); } printf("Center: (%d, %d)\n", cX, cY); } cvReleaseImage(&image); cvReleaseMat(&binaryImage); cvReleaseMemStorage(&storage); return 0; } ``` 请注意,在C版本的OpenCV中,使用的是IplImage和CvMat来表示图像,使用CvMemStorage和CvSeq来处理轮廓。 以上两个示例代码中的input.png是作为输入图像的文件名。你需要根据实际图像的文件名进行修改。

OpenCV C++ 轮廓提取坐标和中心点并在原图中显示的代码

### 回答1: 以下是 OpenCV C 语言的轮廓提取坐标和中心点并在原图中显示的代码: ```c #include <opencv2/opencv.hpp> #include <iostream> using namespace cv; using namespace std; int main() { Mat src = imread("test.jpg"); Mat gray, binary; cvtColor(src, gray, COLOR_BGR2GRAY); threshold(gray, binary, , 255, THRESH_BINARY | THRESH_OTSU); vector<vector<Point>> contours; vector<Vec4i> hierarchy; findContours(binary, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point()); Mat dst = src.clone(); for (size_t i = ; i < contours.size(); i++) { drawContours(dst, contours, i, Scalar(, , 255), 2, 8, hierarchy); Moments mu = moments(contours[i], false); Point2f center(mu.m10 / mu.m00, mu.m01 / mu.m00); circle(dst, center, 2, Scalar(, 255, ), 2, 8, ); cout << "Contour " << i << " center: " << center << endl; } imshow("src", src); imshow("dst", dst); waitKey(); return ; } ``` 希望能对你有所帮助。 ### 回答2: 下面是一个使用OpenCV C++库来提取图像轮廓、计算轮廓中心点并在原图中显示的示例代码: ```cpp #include <opencv2/opencv.hpp> using namespace cv; int main() { // 读取图像 Mat image = imread("image.jpg", IMREAD_COLOR); // 灰度化图像 Mat gray; cvtColor(image, gray, COLOR_BGR2GRAY); // 二值化图像 Mat binary; threshold(gray, binary, 100, 255, THRESH_BINARY); // 查找轮廓 std::vector<std::vector<Point>> contours; findContours(binary, contours, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE); // 绘制轮廓 drawContours(image, contours, -1, Scalar(0, 0, 255), 2); for (const auto& contour : contours) { // 计算轮廓的矩 Moments moments = moments(contour); double cx = moments.m10 / moments.m00; double cy = moments.m01 / moments.m00; // 绘制中心点 circle(image, Point(cx, cy), 4, Scalar(0, 255, 0), -1); } // 显示结果图像 imshow("Contours", image); waitKey(0); return 0; } ``` 代码中,首先读取图像,并将其转换为灰度图像。然后,通过二值化处理将图像转换为黑白图像。 之后,使用`findContours`函数查找图像中的轮廓。参数`RETR_EXTERNAL`表示只检测最外层的轮廓,`CHAIN_APPROX_SIMPLE`表示使用简化的轮廓表示方法。 接着,使用`drawContours`函数在原图像上绘制轮廓线。 对于每个轮廓,通过计算矩的方式计算出轮廓的中心点坐标。最后,使用`circle`函数绘制出每个轮廓的中心点。 最后,将处理后的图像显示出来,等待用户按键退出。 ### 回答3: 以下是使用OpenCV C库进行轮廓提取、坐标和中心点计算,并在原图中显示的示例代码: ```c #include <opencv2/opencv.hpp> using namespace cv; int main() { // 读取图像 Mat image = imread("image.jpg", IMREAD_COLOR); // 灰度图 Mat gray; cvtColor(image, gray, COLOR_BGR2GRAY); // 二值化 Mat binary; threshold(gray, binary, 128, 255, THRESH_BINARY); // 轮廓检测 std::vector<std::vector<Point>> contours; std::vector<Vec4i> hierarchy; findContours(binary, contours, hierarchy, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE); // 遍历轮廓 for (int i = 0; i < contours.size(); i++) { // 绘制轮廓 drawContours(image, contours, i, Scalar(0, 0, 255), 2); // 计算轮廓的边界框 Rect bbox = boundingRect(contours[i]); // 提取坐标 Point tl = bbox.tl(); Point br = bbox.br(); // 计算中心点 Point center = (tl + br) / 2; // 在原图中显示坐标和中心点 putText(image, "Top Left: (" + std::to_string(tl.x) + ", " + std::to_string(tl.y) + ")", tl, FONT_HERSHEY_SIMPLEX, 0.5, Scalar(0, 255, 0), 1); putText(image, "Bottom Right: (" + std::to_string(br.x) + ", " + std::to_string(br.y) + ")", br, FONT_HERSHEY_SIMPLEX, 0.5, Scalar(0, 255, 0), 1); putText(image, "Center: (" + std::to_string(center.x) + ", " + std::to_string(center.y) + ")", center, FONT_HERSHEY_SIMPLEX, 0.5, Scalar(0, 255, 0), 1); } // 显示结果 imshow("Contours", image); waitKey(0); return 0; } ``` 此示例代码通过读取名为"image.jpg"的图像,并使用OpenCV进行轮廓提取、坐标和中心点计算。然后,使用绘制轮廓和putText函数将坐标和中心点信息显示在原图中。最后,通过imshow函数显示结果。

相关推荐

最新推荐

recommend-type

【图像压缩】 GUI矩阵的奇异值分解SVD灰色图像压缩【含Matlab源码 4359期】.zip

Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主或扫描视频QQ名片; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

云原生架构与soa架构区别?

云原生架构和SOA架构是两种不同的架构模式,主要有以下区别: 1. 设计理念不同: 云原生架构的设计理念是“设计为云”,注重应用程序的可移植性、可伸缩性、弹性和高可用性等特点。而SOA架构的设计理念是“面向服务”,注重实现业务逻辑的解耦和复用,提高系统的灵活性和可维护性。 2. 技术实现不同: 云原生架构的实现技术包括Docker、Kubernetes、Service Mesh等,注重容器化、自动化、微服务等技术。而SOA架构的实现技术包括Web Services、消息队列等,注重服务化、异步通信等技术。 3. 应用场景不同: 云原生架构适用于云计算环境下的应用场景,如容器化部署、微服务
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这
recommend-type

数字舵机控制程序流程图

以下是数字舵机控制程序的流程图: ![数字舵机控制程序流程图](https://i.imgur.com/2fgKUQs.png) 1. 初始化引脚:设置舵机控制引脚为输出模式。 2. 初始化舵机:将舵机控制引脚输出的PWM信号设置为初始值,初始化舵机的位置。 3. 接收控制信号:通过串口或者其他方式接收舵机控制信号。 4. 解析控制信号:解析接收到的控制信号,确定舵机需要转动的角度和方向。 5. 转动舵机:根据解析后的控制信号,设置舵机控制引脚输出的PWM信号的占空比,使舵机转动到目标位置。 6. 延时:为了保证舵机转动到目标位置后稳定,需要延时一段时间。 7. 返回接收控制信
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。