OpenCV绘图函数(7)从一个椭圆定义中提取出多边形的顶点坐标函数ellipse2Poly()的使用

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

算法描述

近似一个椭圆弧为一个多边形线。

函数 ellipse2Poly 计算近似指定椭圆弧的多边形线的顶点。它被 ellipse 函数所使用。如果 arcStart 大于 arcEnd,它们会被交换。

函数原型1

cpp 复制代码
void cv::ellipse2Poly
(
	Point 	center,
	Size 	axes,
	int 	angle,
	int 	arcStart,
	int 	arcEnd,
	int 	delta,
	std::vector< Point > & 	pts 
)		

参数1

  • 参数center 弧的中心。
  • 参数axes 椭圆主轴长度的一半。详情参见椭圆部分。
  • 参数angle 椭圆的旋转角度(度数)。详情参见椭圆部分。
  • 参数arcStart 椭圆弧的起始角度(度数)。
  • 参数arcEnd 椭圆弧的结束角度(度数)。
  • 参数delta 相邻折线顶点之间的角度。它定义了近似精度。
  • 参数pts 输出的折线顶点向量。

函数原型2

这是重载的成员函数,为方便提供。它与上面的函数仅在所接受的参数方面有所不同。

cpp 复制代码
oid cv::ellipse2Poly	
(
	Point2d 	center,
	Size2d 	axes,
	int 	angle,
	int 	arcStart,
	int 	arcEnd,
	int 	delta,
	std::vector< Point2d > & 	pts 
)		

参数2

  • 参数center 弧的中心。
  • 参数axes 椭圆主轴长度的一半。详情参见椭圆部分。
  • 参数angle 椭圆的旋转角度(度数)。详情参见椭圆部分。
  • 参数arcStart 椭圆弧的起始角度(度数)。
  • 参数arcEnd 椭圆弧的结束角度(度数)。
  • 参数delta 相邻折线顶点之间的角度。它定义了近似精度。
  • 参数pts 输出的折线顶点向量。

代码示例

近似一个椭圆弧并将其绘制到图像上:

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <iostream>

int main()
{
    // 创建一个空白图像
    cv::Mat image = cv::Mat::zeros(400, 400, CV_8UC3);

    // 设置椭圆弧的参数
    cv::Point center(200, 200); // 椭圆中心
    cv::Size axes(100, 50);     // 主轴和次轴的一半长度
    double angle = 30;          // 椭圆旋转角度
    double arcStart = 0;        // 起始角度
    double arcEnd = 180;        // 结束角度
    double delta = 5;           // 角度增量
    std::vector<cv::Point> pts; // 输出的多边形顶点向量

    // 使用 ellipse2Poly 函数计算椭圆弧的顶点
    cv::ellipse2Poly(center, axes, angle, arcStart, arcEnd, delta, pts);

    // 绘制近似的椭圆弧
    cv::polylines(image, pts, false, cv::Scalar(0, 0, 255), 2, cv::LINE_8);

    // 显示图像
    cv::namedWindow("Ellipse Arc Drawing", cv::WINDOW_NORMAL);
    cv::imshow("Ellipse Arc Drawing", image);
    cv::waitKey(0);

    return 0;
}

运行结果

相关推荐
千宇宙航3 小时前
闲庭信步使用图像验证平台加速FPGA的开发:第十四课——图像二值化的FPGA实现
图像处理·计算机视觉·fpga开发
橡晟3 小时前
深度学习入门:让神经网络变得“深不可测“⚡(二)
人工智能·python·深度学习·机器学习·计算机视觉
墨尘游子3 小时前
神经网络的层与块
人工智能·python·深度学习·机器学习
Leah01053 小时前
什么是神经网络,常用的神经网络,如何训练一个神经网络
人工智能·深度学习·神经网络·ai
PyAIExplorer4 小时前
图像亮度调整的简单实现
人工智能·计算机视觉
Striker_Eureka5 小时前
DiffDet4SAR——首次将扩散模型用于SAR图像目标检测,来自2024 GRSL(ESI高被引1%论文)
人工智能·目标检测
Rvelamen6 小时前
LLM-SECURITY-PROMPTS大模型提示词攻击测评基准
人工智能·python·安全
AI technophile6 小时前
OpenCV计算机视觉实战(15)——霍夫变换详解
人工智能·opencv·计算机视觉
JNU freshman7 小时前
计算机视觉 之 数字图像处理基础(一)
人工智能·计算机视觉
千宇宙航7 小时前
闲庭信步使用图像验证平台加速FPGA的开发:第十五课——基于sobel算子边缘检测的FPGA实现
图像处理·计算机视觉·fpga开发