OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

围绕一组2D点拟合一个椭圆。

该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据可能包含负索引。”

fitEllipse 函数是 OpenCV 库中的一个常用函数,用于拟合一个椭圆来描述一组点。这个函数通常用于图像处理和计算机视觉任务中,例如物体检测、形状分析等。

函数原型


RotatedRect cv::fitEllipse
(	
	InputArray 	points
)	

参数

  • 参数points 输入的2D点集。这些点可以存储在 std::vector 或 Mat 中。

代码示例


#include <opencv2/opencv.hpp>
#include <vector>

using namespace cv;

int main()
{
    // 创建一个空白图像
    Mat img( 400, 400, CV_8UC3, Scalar( 255, 255, 255 ) );

    // 创建一组2D点
    std::vector< Point2f > points;
    points.push_back( Point2f( 150, 100 ) );
    points.push_back( Point2f( 100, 150 ) );
    points.push_back( Point2f( 200, 150 ) );
    points.push_back( Point2f( 200, 250 ) );
    points.push_back( Point2f( 100, 250 ) );
    points.push_back( Point2f( 150, 300 ) );


    // 拟合椭圆
    RotatedRect ellipse2 = fitEllipse( points );

    // 绘制拟合的椭圆
    Point2f center = ellipse2.center;  // 椭圆中心
    Size2f axes    = ellipse2.size;    // 轴长
    float angle    = ellipse2.angle;   // 旋转角度
    ellipse( img, center, axes, angle, 0, 360, Scalar( 0, 0, 255 ), 2 );
    

    // 绘制原始点
    for ( const auto& pt : points )
    {
        circle( img, pt, 5, Scalar( 0, 255, 0 ), -1 );
    }

    // 显示结果
    namedWindow( "Ellipse Fitting", WINDOW_AUTOSIZE );
    imshow( "Ellipse Fitting", img );
    waitKey( 0 );

    return 0;
}

运行结果

在这里插入图片描述

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值