跳转到内容

usd_flattenedprimvar

始于版本18.0

<type>[] usd_flattenedprimvar(<stage>stage, string primpath, string name)

<type>[] usd_flattenedprimvar(<stage>stage, string primpath, string name, float timecode)

此函数返回指定图元上展开后的primvar值。

某些primvar可能被索引,其中primvar是唯一值的压缩数组,并通过索引数组将实体映射到值元素。此函数使用索引数组展开压缩数组,并返回展开后的值数组。

<stage>

在节点上下文(如wrangle LOP节点)中运行时,此参数可以是表示输入编号(从0开始)的整数,用于读取场景。该整数等效于引用特定输入的字符串形式,例如”opinput:0”。

您也可以使用此参数引用USD文件(例如”/path/to/file.usd”),或通过op:路径前缀引用其他LOP节点的已处理场景(例如”op:/stage/lop_node”)。

primpath

图元路径。

name

Primvar名称(不带命名空间)。

timecode

评估属性时使用的USD时间码。USD时间码大致对应于Houdini中的帧数。若未指定,则使用当前帧对应的时间码。

返回值

现有primvar的展开值,若primvar不存在则返回零/空值。如需检查primvar是否存在,请使用usd_isprimvar

示例

// 获取立方体图元上展开primvar的值
float flat_values[] = usd_flattenedprimvar(0, "/geo/cube", "primvar_name");
f[]@flat_primvar_at_current_frame = usd_flattenedprimvar(0, "/geo/sphere", "bar");
f[]@flat_primvar_at_frame_7 = usd_flattenedprimvar(0, "/geo/sphere", "bar", 7.0);