opencascade Adaptor3d_CurveOnSurface源码学习

news/2025/1/9 17:13:53/文章来源:https://www.cnblogs.com/yzxxty/p/18423054

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.hqwc.cn/news/800731.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

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 压力太大,没法正常响应,需要短期内、临时性地提升一些性能。 ​ 我以前做业务护航的时候,就偶尔会碰上这种场景。用户的开发…

C++ 数据算数类型

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

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

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

API接口12种安全措施

1. 使用HTTPS:确保数据传输过程中的安全性。2. 使用OAuth2:一种授权框架,用于授权第三方应用访问服务器上的用户数据。3. 使用WebAuthn:一种网络认证标准,用于安全地进行用户认证。4. API进行签名加密:对API请求进行签名以确保请求的完整性和真实性。5. 黑白名单:限制访…

opencascade Bnd_Range源码学习区间计算

opencascade Bnd_Range 前言这个类描述了由两个实数值限定的 1D 空间中的区间。 一个区间可以是无效的,这表示区间中不包含任何点。 方法 1 默认构造函数。创建一个无效区间。 Bnd_Range() ; 2 构造函数。创建最小最大值区间 Bnd_Range(const Standard_Real theMin, const St…

P2414 [NOI2011] 阿狸的打字机

题目思路 将每一个输出的串放入一个 Trie 树中。 考虑离线处理询问 \((x, y)\),对于每一个 \(y\) 集中处理所有的 \(x\),\(y\) 在 Trie 树上走,走过的点标记一下,结果就是 \(x\) 字符串结尾节点在 fail 树上的对应节点的子树的标记数量。 记得在节点离开的时候撤销标记。 代…

0920

线代 舒尔公式,化上三角,下三角,对角阵 范德蒙德行列式 X型行列式,{主对角中下标之和为(2k+1)的两项乘积-副对角中下标之和为(2k+1)的两项乘积【需与前面两项下标号相同】}的连乘 宽对角,a2=4bc,a2≠4bc计组 MAR位数说明存储单元位数 MDR位数说明字长 编译器:将高级语…

DeepFM

参考资料:https://blog.csdn.net/u012328159/article/details/122938925 https://blog.csdn.net/u012328159/article/details/120684544?spm=1001.2014.3001.5501DeepFM FM部分 目前在模型层面做交叉特征的难点主要有以下两个方面:交叉特征的参数独立,强依赖于在样本中的共…

米尔STM32MP2核心板首发新品上市!高性能+多接口+边缘算力

米尔发布基于STM32MP257设计的嵌入式处理器模块MYC-LD25X核心板及开发板。核心板基于STM32MP2系列是意法半导体推出最新一代工业级64位微处理器,采用LGA 252 PIN设计,存储配置1GB/2GB LPDDR4、8GB eMMC,具有丰富的通讯接口,适用于高端工业HMI、边缘计算网关、新能源充电桩、…