当前位置: 首页 > article >正文

OCCT知识笔记之OCAF框架详解

OCAF框架在OCCT项目中的构建与使用指南

Open CASCADE Application Framework (OCAF)是Open CASCADE Technology (OCCT)中用于管理CAD数据的核心框架,它提供了一种结构化方式来组织和管理复杂的CAD数据,如装配体、形状、属性(颜色、材料)和元数据等。本文将详细介绍如何在项目中构建和使用OCAF框架。

 1. OCAF核心概念与架构

OCAF基于三个核心概念构建:应用(Application)、文档(Document)和属性(Attribute),采用树形结构组织数据。

1.1 核心组件

文档(TDocStd_Document): 所有数据的容器,表示一个层次化的树形结构,根节点是Main标签(TDF_Label)
标签(TDF_Label): 数据组织的基本单元,每个标签有唯一路径(如0:1:2),支持层次结构
属性(TDF_Attribute): 存储实际数据,如几何形状(TNaming_NamedShape)、名称(TDataStd_Name)、数值(TDataStd_Integer)等

1.2 架构优势

OCAF提供了以下服务,简化CAD应用开发:

| 开发任务 | 不使用OCAF | 使用OCAF |
|--------------|-------------------|----------------|
| 创建几何 | 用户实现        | 用户实现 |
| 数据组织 | 用户实现        | 简化 |
| 文件存储 | 用户实现        | 提供 |
| 文档视图管理 | 用户实现 | 提供 |
| 应用基础设施 | 用户实现 | 提供 |
| 撤销与重做 | 用户实现     | 提供 |

2. OCAF项目构建步骤

2.1 环境配置

首先确保项目中包含必要的OCCT库,特别是TKCAF、TKLCAF和TKBin模块。

2.2 创建OCAF文档
#include <TDocStd_Application.hxx>
#include <TDocStd_Document.hxx>
#include <BinLDrivers.hxx>

Handle(TDocStd_Document) CreateOCAFDocument() {
    // 创建应用实例
    Handle(TDocStd_Application) app = new TDocStd_Application();
    
    // 注册二进制格式支持
    BinLDrivers::DefineFormat(app); 
    
    // 创建新文档
    Handle(TDocStd_Document) doc;
    app->NewDocument("BinXCAF", doc);
    
    return doc;
}
 

2.3 添加标签和属性
#include <TDataStd_Name.hxx>
#include <TDataStd_Integer.hxx>
#include <TNaming_NamedShape.hxx>
#include <TopoDS_Shape.hxx>

void AddLabelData(const Handle(TDocStd_Document)& doc) {
    // 获取根标签
    TDF_Label root = doc->Main(); 
    
    // 添加子标签
    TDF_Label comp1 = root.NewChild();
    TDF_Label shape1 = comp1.NewChild();
    
    // 添加名称属性
    comp1.AddAttribute(TDataStd_Name::Set(comp1, "Component1"));
    
    // 添加整数属性
    TDataStd_Integer::Set(comp1, 42);
    
    // 添加形状属性(假设已创建形状)
    TopoDS_Shape someShape; 
    TNaming_NamedShape::Set(shape1, someShape);
}
 

2.4 遍历标签结构
#include <TDF_ChildIterator.hxx>

void TraverseLabels(const TDF_Label& label, int depth = 0) {
    TCollection_AsciiString entry;
    label.Entry(entry);
    std::cout << std::string(depth * 2, ' ') << "Label: " << entry.ToCString() << std::endl;
    
    // 递归遍历子标签
    for (TDF_ChildIterator it(label); it.More(); it.Next()) {
        TraverseLabels(it.Value(), depth + 1);
    }
}
 

3. 数据持久化

OCAF支持多种格式的数据持久化,包括二进制(BinXCAF)和XML(XmlXCAF)格式。

3.1 保存文档
#include <BinLDrivers.hxx>
#include <BinLDriver.hxx>

void SaveDocument(const Handle(TDocStd_Document)& doc, const std::string& filename) {
    BinLDriver::Write(doc, filename.c_str());
}
 

3.2 加载文档
Handle(TDocStd_Document) LoadDocument(const std::string& filename) {
    Handle(TDocStd_Application) app = new TDocStd_Application();
    BinLDrivers::DefineFormat(app);
    Handle(TDocStd_Document) doc;
    app->Open(filename.c_str(), doc);
    return doc;
}
 

4. 高级功能实现

4.1 撤销/重做机制

OCAF内置了强大的撤销/重做功能,通过事务(Transaction)机制实现:
// 开始事务
doc->NewCommand();

// 执行修改操作
TDF_Label newLabel = root.NewChild();
newLabel.AddAttribute(TDataStd_Name::Set(newLabel, "NewComponent"));

// 提交事务
doc->CommitCommand();

// 撤销
doc->Undo();

// 重做
doc->Redo();
 

4.2 引用键模型(Reference-Key Model)

OCAF使用引用键模型维护数据标识,特别是在参数化建模中:

1. 几何形状作为Shape属性的值存储在标签上
2. 修改参数时,命名算法(Naming)维护拓扑元素的引用
3. 即使形状改变,属性仍附着在正确的拓扑元素上

4.3 工具类使用

OCAF提供了一系列工具类简化常见操作:

| 工具类                           | 功能                      |
|--------------------------------|--------------------------|
| XCAFDoc_ShapeTool   | 管理形状数据(TopoDS_Shape) |
| XCAFDoc_ColorTool     | 管理颜色属性 |
| XCAFDoc_LayerTool     | 管理图层信息 |
| XCAFDoc_MaterialTool | 管理材料属性 |

使用示例:
#include <XCAFDoc_ShapeTool.hxx>
#include <XCAFDoc_ColorTool.hxx>

// 获取形状工具
Handle(XCAFDoc_ShapeTool) shapeTool = XCAFDoc_DocumentTool::ShapeTool(doc->Main());

// 添加形状到文档
TDF_Label shapeLabel = shapeTool->AddShape(someShape);

// 获取颜色工具并设置颜色
Handle(XCAFDoc_ColorTool) colorTool = XCAFDoc_DocumentTool::ColorTool(doc->Main());
colorTool->SetColor(shapeLabel, Quantity_Color(1.0, 0.0, 0.0, Quantity_TOC_RGB), XCAFDoc_ColorGen);
 

5. 实际应用案例

5.1 CAD装配体管理
// 创建装配体结构
TDF_Label assemblyLabel = shapeTool->NewShape();
TDF_Label part1Label = shapeTool->AddComponent(assemblyLabel, part1Shape);
TDF_Label part2Label = shapeTool->AddComponent(assemblyLabel, part2Shape);

// 设置部件属性
part1Label.AddAttribute(TDataStd_Name::Set(part1Label, "Part1"));
part2Label.AddAttribute(TDataStd_Name::Set(part2Label, "Part2"));

// 设置装配体位置
gp_Trsf location;
location.SetTranslation(gp_Vec(10.0, 0.0, 0.0));
shapeTool->SetLocation(part2Label, location);
 

5.2 参数化建模
// 创建参数化圆柱体
Standard_Real radius = 5.0;
Standard_Real height = 10.0;

// 创建底部圆
TDF_Label bottomLabel = root.NewChild();
gp_Pnt bottomCenter(0, 0, 0);
Handle(TNaming_NamedShape)::Set(bottomLabel, BRepBuilderAPI_MakeVertex(bottomCenter));

// 创建顶部圆
TDF_Label topLabel = root.NewChild();
gp_Pnt topCenter(0, 0, height);
Handle(TNaming_NamedShape)::Set(topLabel, BRepBuilderAPI_MakeVertex(topCenter));

// 创建圆柱体侧面
TDF_Label cylinderLabel = root.NewChild();
TopoDS_Shape cylinder = BRepPrimAPI_MakeCylinder(radius, height);
Handle(TNaming_NamedShape)::Set(cylinderLabel, cylinder);

// 更新参数
void UpdateCylinder(TDF_Label cylinderLabel, Standard_Real newRadius, Standard_Real newHeight) {
    // 获取当前形状
    Handle(TNaming_NamedShape) namedShape;
    if (cylinderLabel.FindAttribute(TNaming_NamedShape::GetID(), namedShape)) {
        TopoDS_Shape newCylinder = BRepPrimAPI_MakeCylinder(newRadius, newHeight);
        TNaming_Builder builder(cylinderLabel);
        builder.Generated(newCylinder);
    }
}
 

6. 最佳实践与性能优化

1. 合理组织标签结构:
   - 使用有意义的层次结构(如装配体->部件->特征)
   - 为关键标签添加名称属性方便查找

2. 高效属性访问:
   // 避免频繁查找属性
   Handle(TDataStd_Name) nameAttr;
   if (label.FindAttribute(TDataStd_Name::GetID(), nameAttr)) {
       TCollection_ExtendedString name = nameAttr->Get();
       // 使用名称
   }
   

3. 事务管理:
   - 将相关操作分组到单个事务中
   - 避免在事务中包含用户交互

4. 自定义属性:
   - 尽量使用现有属性组合而非继承创建新属性
   - 必须创建新属性时实现复制和持久化方法

5. 二进制存储优化:
   - 对于大型模型,使用TKBin模块进行二进制存储
   - 考虑使用压缩选项减少文件大小

 7. 常见问题解决

1. 数据丢失问题:
   - 确保所有修改在事务中完成
   - 提交事务前检查错误

2. 性能瓶颈:
   - 避免深层嵌套标签结构
   - 对大模型使用延迟加载策略

3. 版本兼容性:
   - 使用标准属性提高兼容性
   - 为自定义属性提供版本转换机制

4. 多线程访问:
   - OCAF不是线程安全的
   - 使用锁机制或每个线程使用独立文档

OCAF框架为CAD应用开发提供了强大的基础设施,通过合理利用其层次化数据管理、事务机制和内置工具类,可以显著提高开发效率并确保数据一致性。掌握OCAF的核心概念和最佳实践是构建稳健CAD应用的关键。

相关文章:

OCCT知识笔记之OCAF框架详解

OCAF框架在OCCT项目中的构建与使用指南 Open CASCADE Application Framework (OCAF)是Open CASCADE Technology (OCCT)中用于管理CAD数据的核心框架&#xff0c;它提供了一种结构化方式来组织和管理复杂的CAD数据&#xff0c;如装配体、形状、属性(颜色、材料)和元数据等。本文…...

蓝桥杯 16. 外卖店优先级

外卖店优先级 原题目链接 题目描述 “饱了么” 外卖系统中维护着 N 家外卖店&#xff0c;编号 1 ∼ N。每家外卖店都有一个优先级&#xff0c;初始时&#xff08;0 时刻&#xff09;优先级都为 0。 每经过 1 个时间单位&#xff1a; 如果外卖店没有订单&#xff0c;则优先…...

1T 服务器租用价格解析

服务器作为数据存储与处理的核心设备&#xff0c;对于企业和个人开发者而言至关重要。当涉及到租用 1T 服务器时&#xff0c;价格是大家很为关注的要点。然而&#xff0c;1T 服务器租用一个月的费用并非固定不变&#xff0c;而是受到诸多因素的综合影响。​ 影响 1T 服务器租用…...

【JavaWeb】Maven(下)

1 依赖管理 1.1 依赖配置 1.1.1 基本配置 依赖&#xff1a;指当前项目运行所需要的jar包。 一个项目中可以引入多个依赖&#xff1a; 例如&#xff1a;在当前工程中&#xff0c;我们需要用到logback来记录日志&#xff0c;此时就可以在maven工程的pom.xml文件中&#xff0c;引…...

java.lang.ArithmeticException

ArithmeticException算术异常类在java.lang包下&#xff0c;继承RuntimeException运行期异常&#xff0c;算术异常类在Java1.0就有&#xff0c;当发生异常算术条件时抛出算术异常类&#xff0c;譬如除数为0的情况&#xff0c;除数除不尽的情况。 一 异常出现场景 1.1 除数为零…...

openEuler24.03 LTS下安装MySQL8.0.42

目录 前提步骤 删除原有mysql及maridb数据库 安装MySQL 启动MySQL 启动查看MySQL状态 设置MySQL开机自启动 查看登录密码 登录MySQL 修改密码及支持远程连接 远程连接MySQL 前提步骤 拥有openEuler24.03 LTS环境&#xff0c;可参考&#xff1a;Vmware下安装openEule…...

gflags 安装及使用

目录 引言 安装 如何用 gflags 库写代码 如何用命令行使用 gflags 库 gflags 库的其他命令行参数 引言 gflags 是 Google 开发的一个开源库&#xff0c;用于 C 应用程序中命令行参数的声明、定义 和解析。 gflags 库提供了一种简单的方式来添加、解析和文档化命令行标…...

Linux面试题集合(2)

查看系统磁盘使用&#xff0c;当前目录下所有文件夹的使用情况 df -h du -h 更改目录所有人和所有组&#xff0c;包括里面的文件夹下的文件&#xff0c;递归更改 chown -R newowner:newgroup 目录名 只更改文件所有人或者只更改文件所有组 chown newowner file chgrp newgroup …...

致敬经典 << KR C >> 之打印输入单词水平直方图和以每行一个单词打印输入 (练习1-12和练习1-13)

1. 前言 不知道有多少同学正在自学C/C, 无论你是一个在校学生, 还是已经是上班族. 如果你想从事或即将从事软件开发这个行业, C/C都是一个几乎必须要接触的系统级程序开发语言. 虽然现在有Rust更安全的系统级编程语言作为C/C的替代, 但作为入门, C应该还是要好好学的. C最早由B…...

std::ratio<1,1000> 是什么意思?

author: hjjdebug date: 2025年 05月 14日 星期三 09:45:24 CST description: std::ratio<1,1000> 是什么意思&#xff1f; 文章目录 1. 它是一种数值吗&#xff1f;2. 它是一种类型吗&#xff1f;3. std:ratio 是什么呢&#xff1f;4. 分析一个展开后的模板函数5.小结: …...

基于Llama3的开发应用(二):大语言模型的工业部署

大语言模型的工业部署 0 前言1 ollama部署大模型1.1 ollama简介1.2 ollama的安装1.3 启动ollama服务1.4 下载模型1.5 通过API调用模型 2 vllm部署大模型2.1 vllm简介2.2 vllm的安装2.3 启动vllm模型服务2.4 API调用 3 LMDeploy部署大模型3.1 LMDeploy简介3.2 LMDeploy的安装3.3…...

2025.05.17淘天机考笔试真题第三题

&#x1f4cc; 点击直达笔试专栏 &#x1f449;《大厂笔试突围》 &#x1f4bb; 春秋招笔试突围在线OJ &#x1f449; 笔试突围OJ 03. 奇偶平衡树分割问题 问题描述 K小姐是一位园林设计师&#xff0c;她设计了一个由多个花坛组成的树形公园。每个花坛中种植了不同数量的花…...

windows 10 做服务器 其他电脑无法访问,怎么回事?

一般我们会先打开win10自己的防火墙策略&#xff0c;但是容易忽略 电脑之间 路由器上的防火墙&#xff0c;此时也需要查看一下&#xff0c;可以尝试先关闭路由器防火墙&#xff0c;如果可以了&#xff0c;再 设置路由器上的防火墙规则。 将路由器的上网设置 改成 路由模式 &a…...

Linux进程信号处理(26)

文章目录 前言一、信号的处理时机处理情况“合适”的时机 二、用户态与内核态概念重谈进程地址空间信号的处理过程 三、信号的捕捉内核如何实现信号的捕捉&#xff1f;sigaction 四、信号部分小结五、可重入函数六、volatile七、SIGCHLD 信号总结 前言 这篇就是我们关于信号的最…...

【从设置到上传的全过程】本地多个hexo博客,怎么设置ssh才不会互相影响

偶然间&#xff0c;想多建一个博客&#xff0c;但电脑已经有一个博客了&#xff0c;怎么设置ssh才不会互相影响呢&#xff1f; 在 Windows 系统上设置多个 Hexo 博客的 SSH 配置&#xff0c;避免互相影响&#xff0c;通常户就需要为每个博客配置不同的 SSH 密钥&#xff0c;并…...

顶层架构 - 消息集群推送方案

一、推送基础概念简述 在即时通讯&#xff08;IM&#xff09;系统中&#xff0c;最基础的一件事就是“如何把消息推送给用户”。为了实现这个过程&#xff0c;我们要先了解两种常见的网络通信方式&#xff1a;HTTP 和 WebSocket。 1. HTTP 是什么&#xff1f; HTTP 就像一次性…...

Python训练打卡Day26

函数专题1&#xff1a;函数定义与参数 知识点回顾&#xff1a; 函数的定义变量作用域&#xff1a;局部变量和全局变量函数的参数类型&#xff1a;位置参数、默认参数、不定参数传递参数的手段&#xff1a;关键词参数传递参数的顺序&#xff1a;同时出现三种参数类型时 到目前为…...

构建优雅对象的艺术:Java 建造者模式的架构解析与工程实践

一、建造者模式的本质与核心价值 在面向对象的软件设计中&#xff0c;创建复杂对象一直是一个需要精心处理的问题。当一个对象的构建需要多个步骤&#xff0c;并且这些步骤具有不同的组合方式时&#xff0c;传统的构造函数方式会显得力不从心。建造者模式&#xff08;Builder …...

报表控件stimulsoft教程:如何在报表和仪表板中创建热图

Stimulsoft Ultimate &#xff08;原Stimulsoft Reports.Ultimate&#xff09;是用于创建报表和仪表板的通用工具集。该产品包括用于WinForms、ASP.NET、.NET Core、JavaScript、WPF、PHP、Java和其他环境的完整工具集。无需比较产品功能&#xff0c;Stimulsoft Ultimate包含了…...

(8)python开发经验

文章目录 1 下载python2 pip安装依赖无法访问3 系统支持4 下载python文档5 设置虚拟环境6 编译安装python 更多精彩内容&#x1f449;内容导航 &#x1f448;&#x1f449;Qt开发 &#x1f448;&#x1f449;python开发 &#x1f448; 1 下载python 下载地址尽量不要下载最新版…...

0x08.Redis 支持事务吗?如何实现?

回答重点 Redis 支持事务,但它的事务与 MySQL 等关系型数据库的事务有着本质区别。MySQL 中的事务严格遵循 ACID 特性,而 Redis 中的事务主要保证的是命令执行的原子性和隔离性,即所有命令在一个不可分割的操作中顺序执行,不会被其他客户端的命令请求所打断。 最关键的区…...

win32相关(字符编码)

字符编码 ASCII编码 ASCII&#xff08;American Standard Code for Information Interchange&#xff0c;美国信息交换标准代码&#xff09;是最基础的字符编码标准&#xff0c;用于在计算机和其他设备中表示文本 基本概念 7位编码&#xff1a; ASCII使用7位二进制数&#x…...

使用Langfuse和RAGAS,搭建高可靠RAG应用

大家好&#xff0c;在人工智能领域&#xff0c;RAG系统融合了检索方法与生成式AI模型&#xff0c;相比纯大语言模型&#xff0c;提升了准确性、减少幻觉且更具可审计性。不过&#xff0c;在实际应用中&#xff0c;当建好RAG系统投入使用时&#xff0c;如何判断接收信息是否正确…...

VSCode + Cline AI辅助编程完全指南

VSCode Cline AI辅助编程完全指南 在当今AI快速发展的时代&#xff0c;程序员可以通过AI工具极大地提高工作效率。本教程将详细介绍如何使用VSCode结合Cline&#xff08;Claude AI助手&#xff09;进行AI辅助编程&#xff0c;帮助你提高开发效率&#xff0c;解决复杂问题。 …...

android studio导入项目

如果 gradle-8.0-bin.zip 没有下载成功 可以点击进入这个网站&#xff1a;https://services.gradle.org/distributions/ 找到和自己本版相同的gradle-8.0-bin.zip文件找到自己版本进行下载; 如果下载依赖失败, 可以手动下载依赖编译过程中的jar https://repo.maven.apache.org/…...

Autosar Nvm下电存储实现方式-基于ETAS工具

文章目录 前言Autosar Nvm相关定义Nvm Ram Block States状态切换Nvm_WriteAll函数NvBlock配置生成代码分析及使用总结前言 Nvm中存储的数据,一般有两种存储方式,一个是立即存,一个是下电存,之前介绍过立即存的配置,本文介绍下电存的配置及实现 Autosar Nvm相关定义 Nvm…...

c# 数据结构 树篇 入门树与二叉树的一切

事先声明,本文不适合对数据结构完全不懂的小白 请至少学会链表再阅读 c# 数据结构 链表篇 有关单链表的一切_c# 链表-CSDN博客 数据结构理论先导:《数据结构&#xff08;C 语言描述&#xff09;》也许是全站最良心最通俗易懂最好看的数据结构课&#xff08;最迟每周五更新~~&am…...

Python Bug 修复案例分析:asyncio 事件循环异常引发的程序崩溃 两种修复方法

在 Python 异步编程的工作中&#xff0c;asyncio库为我们提供了高效处理并发任务的强大工具。然而&#xff0c;asyncio在使用过程中也可能因为一些细节处理不当而引发 Bug。下面&#xff0c;我们就来深入分析一个因asyncio事件循环异常导致程序崩溃的典型案例。兴趣的友友可以借…...

题单:递归求和

宣布一个重要的事情&#xff0c;我的洛谷有个号叫 题目描述 给一个数组 a:a[0],a[1],...,a[n−1]a:a[0],a[1],...,a[n−1] 请用递归的方式出数组的所有数之和。 提示&#xff1a;递推方程 f(x)f(x−1)a[x]f(x)f(x−1)a[x]; 输入格式 第一行一个正整数 n (n≤100)n (n≤100)…...

融智学视域下的系统性认知增强框架——基于文理工三类AI助理赋能HI四阶跃迁路径

融智学视域下的系统性认知增强框架 ——基于文理工三类AI助理赋能HI四阶跃迁路径 一、如何排除50个认知偏差&#xff1a;消除50类偏差的精准矫正系统 1. 技术架构 文科AI&#xff1a; 构建文化语义场&#xff08;Cultural Semantic Field, CSF&#xff09;&#xff0c;通过…...