翻译HoudiniEngine官方文档:Parts

2024-09-06 23:18

本文主要是介绍翻译HoudiniEngine官方文档:Parts,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

官方文档:《Houdini Engine 3.6: Parts》

介绍

Part 包含了你实际感兴趣的 mesh几何体attribute 数据。

Part 的划分基于几何体 primitivegroup 。每一个 primitive group 对应一个 Part,如果有不属于任何 group 的几何体则他们将算作一个新的 Part。如果在一个 primitive group 有多个 primitive,则将为每个 primitive 创建额外的 Part。此拆分功能可以通过 HAPI_CookOptions::splitGeosByGroup 来禁用,方式是将其作为参数传入 HAPI_Initialize() 或 HAPI_CookNode() 等其他 API。

查询

要获取 HAPI_PartInfo,只需要对一个 geo(SOP)节点 调用 HAPI_GetPartInfo() 就行了。此函数需要节点的ID和Part的ID。

所谓 “Part的ID” 其实就是 Part 列表中的索引号,列表可能会在每次 cook 时改变内部顺序和尺寸。

而一个 geo 中有多少个 Part 是由 HAPI_GeoInfo::partCount 指定的。

获得几何体数据

调用 HAPI_GetFaceCounts() 并将 0 和HAPI_PartInfo::faceCount作为范围传入。可以得到一个数组,其中数组中的第n个整数是第n个面具有的顶点数。

如果想获得 vertex - point 对应关系的数组,你可以调用 HAPI_GetVertexList() 并将0和 HAPI_PartInfo::vertexCount作为范围传入。其中数组中的第i个元素是第i个 vertex 关联的 point 的索引。例如:如果第一个面有3个 vertex ,第二个面有4个 vertex ,第三个面有5个 vertex ,则 VertexList 中的前3个整数是属于第一个面的 point 索引,接下来的4个整数是属于第二个面,接下来的5个整数属于第三个面。

VertexList 仅包含对于 point 的索引,因为 vertex 是共享 point 的。There is a separate list of points, which are a list of 3 vectors, and the vertices index into this list of points. 因此,从 VertexList 中检索的整数是 PointList 中的索引。

Point 实际的位置信息,以及所有其他几何元数据都存储为 Houdini 的 attribute。 可参阅 Attributes。

Part的种类

有几个特殊的Part类型需要注意。HAPI_PartType由HAPI_PartInfo::type给出。 以下是部分类型:

  1. HAPI_PARTTYPE_MESH 是默认的 mesh primitive。
  2. HAPI_PARTTYPE_CURVE 是曲线 primitive。详见 Curves.
  3. HAPI_PARTTYPE_VOLUME 是体数据 primitive。详见 Volumes。
  4. HAPI_PARTTYPE_INSTANCER 是 packed primitive. 详见 Packed Primitives。
  5. HAPI_PARTTYPE_BOX 是 “盒状 primitive”。你可以对这个Part调用 HAPI_GetBoxInfo() 来获得一个 HAPI_BoxInfo 结构体。而且渲染相同的几何体潜在的效率会更高。为了启用 “盒状primitive”,你需要设置 HAPI_CookOptions::handleBoxPartTypes 为 true。
  6. HAPI_PARTTYPE_SPHERE 是“球形 primitive”。你可以对这个Part调用 HAPI_GetSphereInfo() 来获得一个 HAPI_SphereInfo 结构体。而且渲染相同的几何体潜在的效率会更高。为了启用 “球形primitive”,你需要设置HAPI_CookOptions::handleSpherePartTypes 为 true。

这篇关于翻译HoudiniEngine官方文档:Parts的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1143401

相关文章

Python Pillow 库详解文档(最新推荐)

《PythonPillow库详解文档(最新推荐)》Pillow是Python中最流行的图像处理库,它是PythonImagingLibrary(PIL)的现代分支和继承者,本文给大家介绍Pytho... 目录python Pillow 库详解文档简介安装核心模块架构Image 模块 - 核心图像处理基本导入

C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式

《C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式》Markdown凭借简洁的语法、优良的可读性,以及对版本控制系统的高度兼容性,逐渐成为最受欢迎的文档格式... 目录为什么要将文档转换为 Markdown 格式使用工具将 Word 文档转换为 Markdown(.

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

Python使用python-docx实现自动化处理Word文档

《Python使用python-docx实现自动化处理Word文档》这篇文章主要为大家展示了Python如何通过代码实现段落样式复制,HTML表格转Word表格以及动态生成可定制化模板的功能,感兴趣的... 目录一、引言二、核心功能模块解析1. 段落样式与图片复制2. html表格转Word表格3. 模板生

ubuntu系统使用官方操作命令升级Dify指南

《ubuntu系统使用官方操作命令升级Dify指南》Dify支持自动化执行、日志记录和结果管理,适用于数据处理、模型训练和部署等场景,今天我们就来看看ubuntu系统中使用官方操作命令升级Dify的方... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。

浅谈Redis Key 命名规范文档

《浅谈RedisKey命名规范文档》本文介绍了Redis键名命名规范,包括命名格式、具体规范、数据类型扩展命名、时间敏感型键名、规范总结以及实际应用示例,感兴趣的可以了解一下... 目录1. 命名格式格式模板:示例:2. 具体规范2.1 小写命名2.2 使用冒号分隔层级2.3 标识符命名3. 数据类型扩展命

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl