GDAL C++ API 学习之路 OGRGeometry 圆弧类 OGRCircularString

这篇具有很好参考价值的文章主要介绍了GDAL C++ API 学习之路 OGRGeometry 圆弧类 OGRCircularString。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

OGRCircularString Class        <ogrsf_frmts.h>

OGRCircularString 类是 OGR 几何库中的一个类,用于表示圆弧字符串(circular string)类型的几何图形。圆弧字符串是由一系列圆弧段组成的几何图形,每个圆弧段由三个点定义:起始点、中间点和终止点。这些圆弧段可以连接成一个闭合的圆弧字符串,也可以构成一个非闭合的曲线

Public Functions

OGRCircularString()

创建一个空的圆弧字符串

OGRCircularStringconst OGRCircularString &other)

复制构造函数

OGRCircularString &operator=const OGRCircularString &other)

赋值运算符

importFromWkb

virtual OGRErr importFromWkb(const unsigned char*, size_t, OGRwkbVariant, size_t &nBytesConsumedOut) override

从已知的二进制数据中指定几何图形

参数:

  • pabyData -- 二进制输入数据。

  • nSize -- pabyData 的大小(以字节为单位),如果不知道,则为 -1。

  • eWkbVariant -- 如果 wkbVariantPostGIS1,则对曲线几何代码进行特殊解释

  • nBytesConsumptiondOut -- 输出参数。消耗的字节数。

返回:  OGRERR_NONE如果一切顺利,否则OGRERR_NOT_ENOUGH_DATA、OGRERR_UNSUPPORTED_GEOMETRY_TYPE或OGRERR_CORRUPT_DATA中的任何一个都可能被退回

exportToWkb

virtual OGRErr exportToWkb(OGRwkbByteOrder, unsigned char*, OGRwkbVariant = wkbVariantOldOgc) const override

将几何图形转换为众所周知的二进制格式

参数:

  • eByteOrder -- wkbXDR 或 wkbNDR 之一,分别表示 MSB 或 LSB 字节顺序。

  • pabyData -- 写入二进制表示的缓冲区。此缓冲区的大小必须至少为 OGRGeometry::WkbSize() 字节。

  • eWkbVariant -- 导出三维(或更多)几何图形时使用什么标准。默认的 wkbVariantOldOgc 是历史的 OGR 变体。wkbVariantIso 是 ISO SQL/MM 中定义的变体,并被 OGC 用于 SFSQL 1.2。

返回:  当前始终返回OGRERR_NONE

importFromWkt

virtual OGRErr importFromWkt(const char**) override

从已知文本数据中指定几何图形

参数:

ppszInput -- 指向源文本指针的指针。指针将更新为已使用文本之后的指针。

返回:  OGRERR_NONE如果一切顺利,否则OGRERR_NOT_ENOUGH_DATA、OGRERR_UNSUPPORTED_GEOMETRY_TYPE或OGRERR_CORRUPT_DATA中的任何一个都可能被退回

exportToWkt

virtual std::string exportToWkt(const OGRWktOptions &opts = OGRWktOptions(), OGRErr *err = nullptr) const override

将循环字符串导出到 WKT

参数:

  • opts -- 输出选项

  • err -- 指向错误代码的指针(如果需要)。

返回:

表示此循环字符串的 WKT 字符串

IsValid

virtual OGRBoolean IsValid() const override

测试几何图形是否有效

返回:  如果几何图形没有点,则为 TRUE,否则为 FALSE

getEnvelope

virtual void getEnvelope(OGREnvelope *psEnvelope) const override

计算并返回传递的 psEnvelope 结构中此几何图形的边界包络

参数:

psEnvelope -- 放置结果的结构

// 创建一个圆弧几何对象
    OGRCircularString circularString;
    
    // 添加一些点到圆弧
    circularString.addPoint(0, 0);
    circularString.addPoint(1, 1);
    circularString.addPoint(2, 2);
    
    // 创建一个用于存储外包络矩形的结构体
    OGREnvelope envelope;
    
    // 获取圆弧的外包络矩形
    circularString.getEnvelope(&envelope);
    
    // 打印外包络矩形的坐标信息
    std::cout << "MinX: " << envelope.MinX << std::endl;
    std::cout << "MinY: " << envelope.MinY << std::endl;
    std::cout << "MaxX: " << envelope.MaxX << std::endl;
    std::cout << "MaxY: " << envelope.MaxY << std::endl;

getEnvelope

virtual void getEnvelope(OGREnvelope3D *psEnvelope) const override

计算并返回传递的 psEnvelope 结构中此几何图形的边界包络 (3D)

参数:

psEnvelope -- 放置结果的结构

clone

virtual OGRCircularString *clone() const override

创建此对象的副本

返回:  具有与原始对象相同的几何和空间参考系统的新对象实例

get_Length

virtual double get_Length() const override

返回曲线的长度

返回: 曲线的长度,如果曲线尚未初始化,则为零

CurveToLine

virtual OGRLineString *CurveToLine(double dfMaxAngleStepSizeDegrees = 0, const char *const *papszOptions = nullptr) const override

参数:

  • dfMaxAngleStepSizeDegrees -- 沿弧的最大步长(以度为单位),使用默认设置为零。

  • papszOptions -- 选项作为以 null 结尾的字符串列表或 NULL。

返回:  近似曲线的线串

Value

virtual void Value(double, OGRPoint*) const override

沿曲线在给定距离处获取点

参数:

  • dfDistance -- 沿采样位置的曲线的距离。对于此曲线,此距离应介于 0 和 get_Length() 之间。

  • poPoint -- 要指定曲线位置的点

    // 创建一个OGRPoint对象表示圆弧曲线的起点
    OGRPoint startPoint(0.0, 0.0);

    // 创建一个圆弧曲线对象,构建一个圆弧
    OGRCircularString circularString;
    circularString.addPoint(&startPoint);
    circularString.addCircularArc(10.0, 0.0, 20.0);

    // 调用Value函数计算圆弧上的点
    double Distance = 15.0; // 假设给定一个长度
    OGRPoint resultPoint;
    circularString.Value(Distance, &resultPoint);

    // 打印计算得到的点坐标
    std::cout << "Point on circular arc at angle " << angle << ": " << resultPoint.getX() << ", " << resultPoint.getY() << std::endl;

get_Area

virtual double get_Area() const override

获取(闭合)曲线的面积

getGeometryType

virtual OGRwkbGeometryType getGeometryType() const override

获取几何类型

getGeometryName

Virtual const char *getGeometryName() const override

获取几何类型的 WKT 名称

返回:用于此几何类型的名称,采用众所周知的文本格式。返回的指针指向静态内部字符串,不应修改或释放

segmentize

virtual void segmentize(double dfMaxLength) override

修改几何图形,使其没有比给定距离更长的线段

参数:

dfMaxLength -- 分割后 2 点之间的最大距离

// 创建一个圆弧几何对象
    OGRPoint point1(0, 0);
    OGRPoint point2(5, 0);
    OGRPoint point3(10, 0);
    OGRCircularString circularString;
    circularString.addPoint(&point1);
    circularString.addPoint(&point2);
    circularString.addPoint(&point3);

    // 打印原始的圆弧几何对象
    std::cout << "原始圆弧几何对象:" << std::endl;
    char* wkt;
    circularString.exportToWkt(&wkt);
    std::cout << wkt << std::endl;
    CPLFree(wkt);

    // 使用最大长度为2.0的线段对圆弧几何对象进行分段
    circularString.segmentize(2.0);

    // 打印分段后的圆弧几何对象
    std::cout << "分段后的圆弧几何对象:" << std::endl;
    circularString.exportToWkt(&wkt);
    std::cout << wkt << std::endl;
    CPLFree(wkt)

hasCurveGeometry

virtual OGRBoolean hasCurveGeometry(int bLookForNonLinear = FALSE) const override

如果此几何图形是或具有曲线几何图形,则返回此几何图形

  1. 线性几何类型:

    • OGRPoint:点几何类型,表示一个点。
    • OGRLineString:线几何类型,表示一条折线,由一系列连续的线段组成。
    • OGRRing:环几何类型,是线性几何类型的特殊类型,表示闭合的线。环几何类型可以用于表示简单多边形的外环或内环。
  2. 曲线几何类型:

    • OGRCircularString:圆弧几何类型,表示一个圆弧。
    • OGRCompoundCurve:复合曲线几何类型,由多个线段和圆弧组成的复杂曲线。
    • OGRCurvePolygon:曲线多边形几何类型,表示由曲线组成的多边形。曲线多边形由外环和零个或多个内环组成,这些环可以是线性环或圆弧环。
  1. bLookForNonLinear 参数设置为 FALSE 时,表示只查找线性的子几何对象,不查找曲线类型的子几何对象(包括圆弧、复合曲线等)。
  2. bLookForNonLinear 参数设置为 TRUE 时,表示同时查找曲线类型和线性类型的子几何对象

参数:

bLookForNonLinear -- 将其设置为 TRUE 以检查几何图形是否为 CIRCULARSTRING 或包含 CIRCULARSTRING。

返回: 如果此几何图形是或具有曲线几何图形,则为 TRUE

 OGRPoint point(10.0, 20.0);

    //检查点是否具有曲线几何(非线性)。
    if (point.hasCurveGeometry()) {
        std::cout << "The point contains curve geometry." << std::endl;
    } else {
        std::cout << "The point does not contain curve geometry." << std::endl;
    }

getLinearGeometry

virtual OGRGeometry *getLinearGeometry(double dfMaxAngleStepSizeDegrees = 0, const char *const *papszOptions = nullptr) const override

返回此几何图形的非曲线版本,可能是近似值

参数:

  • dfMaxAngleStepSizeDegrees -- 沿弧的最大步长(以度为单位),使用默认设置为零。

  • papszOptions -- 选项作为以 null 结尾的字符串列表。

返回:  新的几何图形

OGRPoint p1(0, 0);
OGRPoint p2(1, 1);
OGRPoint p3(2, 0);

OGRCircularString cs;
cs.addPoint(&p1);
cs.addPoint(&p2);
cs.addPoint(&p3);

// 转换为线性几何对象
OGRGeometry* linearGeom = cs.getLinearGeometry();

在上面的例子中,一开始设置的点在 OGRCircularString 中表示一个圆弧段,可以用中心点、起始点、终止点和半径等信息来表示。但是当将 OGRCircularString 对象转换为线性几何对象时,圆弧段将被拆分成一组连续的直线段,这些直线段近似地组成了原始圆弧的形状。文章来源地址https://www.toymoban.com/news/detail-619268.html

到了这里,关于GDAL C++ API 学习之路 OGRGeometry 圆弧类 OGRCircularString的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java 调用gdal API(二)——栅格裁剪

    gdal可以说是GIS数据处理比较好的工具之一,虽然也提供了Java API,但是官方文档确实太过简单,用起来确实太难受,每次都需要去参考对应的C++api,然后在对应使用。 因此小编决定从这篇文章开始,将自己以前以及今后用到的API,都记录下,以帮助更多从事java GIS服务开发者

    2024年02月16日
    浏览(37)
  • 【计算几何】判断一条线段和一段圆弧是否相交 & C++代码实现

    最近做项目,需要判断一条线段是否和一段圆弧相交,网上也没找到很好的解答(最主要是没有直接可以搬来用的代码,或者思路写得太过高深,我看不懂),于是决定自己想一个方法,写一个博客,将实现思路和完整代码都分享出来 线段可用两个点表示,点的对象如下所示

    2024年02月01日
    浏览(81)
  • C++学习之路(C++初阶)——类和对象(上)

    ✨✨欢迎来到T_X_Parallel的博客!!       🛰️博客主页:T_X_Parallel       🛰️专栏 : C++初阶       🛰️欢迎关注:👍点赞🙌收藏✍️留言       🛰️友友们的支持是本博主更新的动力   本博客主要为学习C++类和对象内容做准备,开头补充

    2024年02月07日
    浏览(57)
  • c++的学习之路:22、多态(1)

    本章主要是说一些多态的开头。 目录 摘要 一、多态的概念 二、多态的定义及实现 2.1、多态的构成条件 2.2、虚函数 2.3、虚函数的重写 2.4、C++11 override 和 final  2.5、重载、覆盖(重写)、隐藏(重定义)的对比 三、思维导图 多态的概念:通俗来说,就是多种形态,具体点就是去

    2024年04月14日
    浏览(71)
  • 【脚本工具】SVG路径中的A指令转DXF的圆弧和椭圆弧 & C++代码实现

    目前Svg的Arc的参数字符串如下:其中,A (绝对) a (相对) 除了 A(a) 表示标识为圆弧之外,其余参数说明如下: 参数 说明 符号 rx 椭圆半长轴 a a a ry 椭圆半短轴 b b b x-axis-rotation 椭圆相对于坐标系的旋转角度,角度数而非弧度数 α alpha α large-arc-flag 是否优(大)弧:0否,1是 f l

    2024年02月06日
    浏览(42)
  • 【C++ Core Guidelines解析】C++学习之路的一盏明灯

    前言: C++语言的功能非常丰富,表达能力非常强。 因为一种成功的通用编程语言拥有的功能必须比任何开发人员所需要的更多,任何一种有生命力且不断发展的语言都会不断积累用于表达程序员思想的替代用法。这会导致选择过载。那么,开发人员应该如何根据编程风格和

    2024年02月09日
    浏览(36)
  • 基于C++、GDAL、OpenCV的矢量数据骨架线提取算法

    基于C++、GDAL、OpenCV的矢量数据骨架线提取算法 CGAL已经实现了该功能,但由于CGAL依赖于Boost库,编译后过大,因此本文所采用的这套方式实现骨架线提取功能。 效果: 思路: 1、将导入shp按照要素逐一拆分成新的shp 2、将所有拆分后的shp分别转栅格,利用OpenCV提取骨架线 3、

    2024年02月12日
    浏览(79)
  • C++学习之路(七)C++ 实现简单的Qt界面(消息弹框、按钮点击事件监听)- 示例代码拆分讲解

    这个示例创建了一个主窗口,其中包含两个按钮。第一个按钮点击时会显示一个简单的消息框,第二个按钮点击时会执行一个特定的操作(在这个例子中,仅打印一条调试信息)。 功能描述: 创建窗口和布局: 使用 QWidget 和 QVBoxLayout 创建主窗口并设置垂直布局,将按钮放置

    2024年02月04日
    浏览(68)
  • C++ GDAL提取多时相遥感影像中像素随时间变化的数值数组

      本文介绍基于 C++ 语言 GDAL 库, 批量读取 大量栅格遥感影像文件,并生成 各像元数值的时间序列 数组的方法。   首先,我们来明确一下本文所需实现的需求。现在有一个文件夹,其中包含了很多不同格式的文件,如下图所示。   其中,我们首先需要遍历这一文件

    2024年02月19日
    浏览(38)
  • 创建大量栅格文件并分别写入像元数据:C++ GDAL代码实现

      本文介绍基于 C++ 语言 GDAL 库, 批量创建 大量栅格遥感影像文件,并将数据批量写入其中的方法。   首先,我们来明确一下本文所需实现的需求。已知我们对 大量遥感影像 进行了批量读取与数据处理操作——具体过程可以参考文章C++ GDAL提取多时相遥感影像中像素随

    2024年02月19日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包