opencascade Adaptor3d_CurveOnSurface源码学习

news/2024/9/20 21:06:22

opencascade Adaptor3d_CurveOnSurface

前言

用于连接由Geom包中表面上的曲线提供的服务,以及使用这条曲线的算法所要求的服务。该曲线被定义为一个二维曲线,来自Geom2d包,位于表面的参数空间中

方法

1

默认构造函数
Standard_EXPORT Adaptor3d_CurveOnSurface();

2

通过给定的表面句柄S构造
Standard_EXPORT Adaptor3d_CurveOnSurface(const Handle(Adaptor3d_Surface)& S);

3

通过给定的二维曲线句柄C和表面句柄S构造
从二维曲线和表面创建CurveOnSurface。
Standard_EXPORT Adaptor3d_CurveOnSurface(const Handle(Adaptor2d_Curve2d)& C, const Handle(Adaptor3d_Surface)& S);

4

适配器的浅拷贝
Standard_EXPORT virtual Handle(Adaptor3d_Curve) ShallowCopy() const Standard_OVERRIDE;

5

更改表面
Standard_EXPORT void Load(const Handle(Adaptor3d_Surface)& S);

6

更改二维曲线
Standard_EXPORT void Load(const Handle(Adaptor2d_Curve2d)& C);

7

同时加载曲线和表面
Standard_EXPORT void Load(const Handle(Adaptor2d_Curve2d)& C, const Handle(Adaptor3d_Surface)& S);

8

获取二维曲线的句柄(常量)
Standard_EXPORT const Handle(Adaptor2d_Curve2d)& GetCurve() const;

9

获取表面的句柄(常量)
Standard_EXPORT const Handle(Adaptor3d_Surface)& GetSurface() const;

10

获取二维曲线的句柄(非常量)
Standard_EXPORT Handle(Adaptor2d_Curve2d)& ChangeCurve();

11

获取表面的句柄(非常量)
Standard_EXPORT Handle(Adaptor3d_Surface)& ChangeSurface();

12

获取曲线的第一个参数
Standard_EXPORT Standard_Real FirstParameter() const Standard_OVERRIDE;

13

获取曲线的最后一个参数
Standard_EXPORT Standard_Real LastParameter() const Standard_OVERRIDE;

14

获取曲线的连续性类型
Standard_EXPORT GeomAbs_Shape Continuity() const Standard_OVERRIDE;

15

返回满足连续性的区间数量
Standard_EXPORT Standard_Integer NbIntervals(const GeomAbs_Shape S) const Standard_OVERRIDE;

16

将满足连续性的区间参数存储在
Standard_EXPORT void Intervals(TColStd_Array1OfReal& T, const GeomAbs_Shape S) const Standard_OVERRIDE;

17

返回在参数之间的曲线等效体,使用来测试3D点的混淆
Standard_EXPORT Handle(Adaptor3d_Curve) Trim(const Standard_Real First, const Standard_Real Last, const Standard_Real Tol) const Standard_OVERRIDE;

18

检查曲线是否闭合
Standard_EXPORT Standard_Boolean IsClosed() const Standard_OVERRIDE;

19

检查曲线是否周期性
Standard_EXPORT Standard_Boolean IsPeriodic() const Standard_OVERRIDE;

20

获取曲线的周期(如果周期性)
Standard_EXPORT Standard_Real Period() const Standard_OVERRIDE;

21

计算参数U在曲线上的点
Standard_EXPORT gp_Pnt Value(const Standard_Real U) const Standard_OVERRIDE;

22

计算参数U在曲线上的点(与D0相同)
Standard_EXPORT void D0(const Standard_Real U, gp_Pnt& P) const Standard_OVERRIDE;

23

计算参数U在曲线上的点及其一阶导数
Standard_EXPORT void D1(const Standard_Real U, gp_Pnt& P, gp_Vec& V) const Standard_OVERRIDE;

24

计算参数U在曲线上的点及其一阶和二阶导数
Standard_EXPORT void D2(const Standard_Real U, gp_Pnt& P, gp_Vec& V1, gp_Vec& V2) const Standard_OVERRIDE;

25

计算参数U在曲线上的点及其一阶、二阶和三阶导数
Standard_EXPORT void D3(const Standard_Real U, gp_Pnt& P, gp_Vec& V1, gp_Vec& V2, gp_Vec& V3) const Standard_OVERRIDE;

26

返回参数U处N阶导数的值
Standard_EXPORT gp_Vec DN(const Standard_Real U, const Standard_Integer N) const Standard_OVERRIDE;

27

返回与三维空间分辨率对应的参数分辨率
Standard_EXPORT Standard_Real Resolution(const Standard_Real R3d) const Standard_OVERRIDE;

28

返回当前区间内曲线的类型:直线、圆、椭圆、双曲线、抛物线、贝塞尔曲线、B样条曲线、其他曲线
Standard_EXPORT GeomAbs_CurveType GetType() const Standard_OVERRIDE;

用法示例

Adaptor3d_CurveOnSurface 是 OpenCascade 中的一个类,用于表示在曲面上的 3D 曲线。这个类通常用于表示 UV 曲线在曲面上的映射,并可以从中提取 3D 曲线的点、导数等信息。下面是一个简单的例子,展示如何使用 Adaptor3d_CurveOnSurface 来在曲面上定义和处理曲线。

例子:在一个平面上创建一个 UV 曲线并使用 Adaptor3d_CurveOnSurface

这个例子展示了如何在平面上定义一个 UV 曲线(例如,直线),并使用 Adaptor3d_CurveOnSurface 来获取曲线在 3D 空间中的点。

#include <Geom_Plane.hxx>
#include <Geom2d_Line.hxx>
#include <GeomAdaptor.hxx>
#include <Adaptor3d_CurveOnSurface.hxx>
#include <BRepBuilderAPI_MakeEdge.hxx>
#include <BRepBuilderAPI_MakeFace.hxx>
#include <BRepTools.hxx>
#include <TopoDS_Shape.hxx>
#include <TopoDS_Face.hxx>
#include <TopoDS_Edge.hxx>int main() {// 创建一个平面gp_Pnt origin(0.0, 0.0, 0.0);gp_Dir normal(0.0, 0.0, 1.0);Handle(Geom_Plane) plane = new Geom_Plane(origin, normal);// 创建一个 UV 线(直线)gp_Pnt2d uvStart(0.0, 0.0);gp_Dir2d uvDir(1.0, 1.0);Handle(Geom2d_Line) uvLine = new Geom2d_Line(uvStart, uvDir);// 创建一个面(用平面创建)TopoDS_Face face = BRepBuilderAPI_MakeFace(plane, Precision::Confusion());// 使用 Adaptor3d_CurveOnSurface 定义曲线Adaptor3d_CurveOnSurface curveOnSurface(uvLine, face);// 获取曲线的 3D 点gp_Pnt point3D;Standard_Real parameter = 0.0;point3D = curveOnSurface.Value(parameter);// 输出 3D 点std::cout << "3D Point: (" << point3D.X() << ", " << point3D.Y() << ", " << point3D.Z() << ")" << std::endl;return 0;
}

代码解释:

  1. 创建平面:

    • 使用 Geom_Plane 创建一个平面,指定了原点和法向量。
  2. 创建 UV 曲线:

    • 使用 Geom2d_Line 创建一个 2D 线(即 UV 曲线)。在参数空间中,这条直线表示一个方向上的线性变化。
  3. 创建面:

    • 使用 BRepBuilderAPI_MakeFace 从平面创建一个面。
  4. 定义曲线:

    • 使用 Adaptor3d_CurveOnSurface 将 UV 曲线与面关联,定义了曲面上的 3D 曲线。
  5. 获取 3D 点:

    • 使用 Value 方法在指定的参数下获取曲线上的 3D 点。

参考
参考链接

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/62708.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

Controller层

@RequestMapping(value = "/url",method = RequestMethod.POST) public String selectXXX(@RequestBody(required = false) String typeName){return ""; }I have a dream : Sandy beach B-J-N.

使用U盘PE重装Windows系统

1、概述 操作系统一般都是安装在硬盘内的,硬盘是一种存储数据的介质,U 盘同样也是一种存储数据的介质,因此也可以把操作系统安装进 U 盘里。 因为大部分 U 盘的性能比较差,不能流畅地运行完整版的操作系统,所以只能安装精简了大部分功能、只保留基本运行环境的简化版操作系…

反射相关API

反射的作用 在不修改源码的情况下,扩展功能。 程序在运行的时期,通过反射机制,获取类的所有内部信息,并且操作类的对象。Class类一个类在堆中只有一个Class对象,这个Class对象包含了类的完整结构信息 反射技术是针对Class对象进行操作,在程序运行的时候,动态获取类中的所…

第二十一讲:MySQL有哪些“饮鸩止渴”提高性能的方法?

第二十一讲:MySQL有哪些“饮鸩止渴”提高性能的方法? 简概引言 ​ 不知道你在实际运维过程中有没有碰到这样的情景:业务高峰期,生产环境的 MySQL 压力太大,没法正常响应,需要短期内、临时性地提升一些性能。 ​ 我以前做业务护航的时候,就偶尔会碰上这种场景。用户的开发…

【游记】CSP2024 游记

初赛 Day 4294967295: LFW:考前做一下前几年初赛卷。 打开 2020 年初赛卷 \(30\ min\) later...... “读程好烦,猜几个直接交了。”一眼丁真,鉴定为 RP=-inf SB 复杂度计算能不能414好,赢。

C++ 数据算数类型

▲ 《C++ Primer》 P30▲ 《C++ Primer》 P38

blender 模拟三键鼠标 alt+鼠标左键 代替 中键 旋转视图,shift+alt+左键 平移视图

blender 模拟三键鼠标 alt+鼠标左键 代替 中键 旋转视图,shift+alt+左键 平移视图--------------------------------------------- 生活的意义就是你自己知道你要做什么,明确目标。没有目标,后面都是瞎扯! https://pengchenggang.gitee.io/navigator/ SMART原则:目标必须是…

用户验收测试指南5过渡阶段的UAT

5 UAT的位置 在本书的这一中心章节中,我们将从准备工作的细节中抽身出来,在沉浸于我们的分步方法的细节之前,先从大局出发。UAT 在更大的计划中处于什么位置?它的核心功能和属性是什么?它的总体贡献是什么? 本章涉及的主题作为一系列过渡的 IS 生命周期 过渡规划 作为过渡…