opencv3.4.0 打开摄像头,检测范围内的圆并输出圆心坐标(c++)

#include <opencv2/opencv.hpp>
#include <opencv2/highgui/highgui_c.h>
#include <iostream>

using namespace cv;
using namespace std;

int main()
{
    char c = 0;
    VideoCapture capture(0);//打开摄像头
    while(1)
    {
    Mat frame;
    capture >>frame;
    Mat midImage; 
    cvtColor(frame,midImage, CV_BGR2GRAY);//转化为灰度图
    GaussianBlur( midImage, midImage, Size(9, 9), 2, 2 );//进行霍夫圆变换
    vector<Vec3f> circles;
    HoughCircles( midImage, circles, CV_HOUGH_GRADIENT,1.5, 10, 200, 100, 0, 0 );//霍夫圆变换
    for( size_t i = 0; i < circles.size(); i++ )
    {
    Point center(cvRound(circles[i][0]), cvRound(circles[i][1]));
    int radius = cvRound(circles[i][2]);//绘制圆心
     circle( frame, center, 3, Scalar(0,255,0), -1, 8, 0 );//打印圆心坐标
     circle( frame, center, radius, Scalar(255,50,255), 3, 8, 0 );//绘制圆轮廓
     printf("x = %d,y = %d\n",cvRound(circles[i][0]),cvRound(circles[i][1]));}
     namedWindow("检测结果");
     imshow("检测结果", frame);
     c = cvWaitKey(30);
     if (c == 27)
     {
     break;
     }
     }
     return 0;
     }

代码有缺陷,霍夫圆测量并不准确

好的,这里给你提供一个基于OpenCVC++代码实现检测追踪小球并给出小球坐标的功能。 ``` #include <opencv2/opencv.hpp> using namespace cv; int main() { // 打开摄像头 VideoCapture cap(0); if (!cap.isOpened()) { std::cout << "Failed to open the camera!" << std::endl; return -1; } // 定义颜色范围 Scalar lower_red(0, 50, 50); Scalar upper_red(10, 255, 255); while (true) { // 读取帧 Mat frame; cap >> frame; // 将图像从BGR转换为HSV颜色空间 cvtColor(frame, frame, COLOR_BGR2HSV); // 提取小球的颜色 Mat mask; inRange(frame, lower_red, upper_red, mask); // 查找小球的轮廓 std::vector<std::vector<Point>> contours; std::vector<Vec4i> hierarchy; findContours(mask, contours, hierarchy, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE); // 找到最大的轮廓 if (contours.size() > 0) { int max_contour_index = 0; double max_contour_area = 0; for (int i = 0; i < contours.size(); i++) { double contour_area = contourArea(contours[i]); if (contour_area > max_contour_area) { max_contour_index = i; max_contour_area = contour_area; } } // 找到小球的圆心和半径 Point2f center; float radius; minEnclosingCircle(contours[max_contour_index], center, radius); // 在图像中标记出小球的位置 circle(frame, center, radius, Scalar(0, 255, 0), 2); putText(frame, "Ball", Point(center.x - 10, center.y - 10), FONT_HERSHEY_SIMPLEX, 0.5, Scalar(0, 255, 0), 2); // 输出小球的坐标 std::cout << "Ball position: (" << center.x << ", " << center.y << ")" << std::endl; } // 显示图像 imshow("frame", frame); // 按下q键退出程序 if (waitKey(1) == 'q') { break; } } // 释放资源 cap.release(); destroyAllWindows(); return 0; } ``` 这里的代码实现和前面的Python代码实现非常相似,只是语法不同。你可以参考一下这个C++代码,并根据自己的需要进行修改。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值