为 Dynamo 2.0+ 定义自定义软件包组织

实现软件包所需的布局取决于将包含在包中的节点类型。“节点模型”派生的节点、ZeroTouch 节点和自定义节点在定义分类方面的过程都略有不同。可以在同一软件包中混合和匹配这些节点类型,但这需要结合使用下面概述的策略。

NodeModel

默认情况下,NodeModel 库基于类结构进行组织。

namespace SampleLibraryUI.Examples
// Class Attribute
[NodeName("MyNodeModel")]
public class MyNewNodeModel : NodeModel

// or

// Constructor
public ButtonCustomNodeModel()
{
    this.Name = "MyNodeModel";
}

节点将位于以下目录下的附加模块中:

SampleLibraryUI/Examples/MyNodeModel

还可以通过在类或构造函数中使用 NodeCategory 属性来覆盖该类别,如下所示。

节点现在将位于以下目录下的附加模块中:

ZeroTouch

默认情况下,ZeroTouch 库也根据类结构进行组织。

节点将位于以下目录下的附加模块中:

还可以使用 Dynamo 自定义 XML 文件替代类结构位置。

  • XML 文件必须相应地命名并包含在软件包的 extra 文件夹中

    • PackageName_DynamoCustomization.xml

CustomNodes

自定义节点是在创建节点(使用新的“自定义节点”对话框)期间根据指定的 Category Name 组织的。

警告! 在节点名称或类别中使用点表示法将产生其他嵌套的子类别。. 将用作分隔符来确定其他层次结构。这是 Dynamo 2.0 库中的新行为。

自定义节点特性

类别名称可以稍后在 .dyf 文件(XML 或 JSON)中更新

软件包节点移植策略

当软件包作者决定在新版本中重命名以前存在的节点时,他们应该提供一种方法来移植包含具有旧名称的节点的图表。这可以通过以下方式完成...

ZeroTouch 节点使用位于软件包 bin 文件夹中的 Namespace.Migrations.XML 文件,例如:

MyZeroTouchLib.MyNodes.SayHelloMyZeroTouchLib.MyNodes.SayHelloRENAMED

NodeModel 派生的节点使用诸如以下类的 AlsoKnownAs 属性:

SampleLibraryUI.Examples.DropDownExampleSampleLibraryUI.Examples.DropDownExampleRENAMED

Last updated