githubEdit

Definiowanie niestandardowej organizacji pakietów dla dodatku Dynamo 2.0+

Osiągnięcie żądanego układu pakietu zależy od typów węzłów, które zostaną uwzględnione w pakiecie. Węzły pochodne Node Model, węzły ZeroTouch i węzły niestandardowe mają nieco inne procesy definiowania kategoryzacji. Możesz mieszać i zestawiać te typy węzłów w tym samym pakiecie, ale będzie to wymagało łączenia różnych strategii opisanych poniżej.

NodeModel

Biblioteki NodeModel są domyślnie zorganizowane w oparciu o strukturę klas.

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

// or

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

Węzeł będzie zlokalizowany w obszarze dodatków w ścieżce:

SampleLibraryUI/Examples/MyNodeModel

Kategorię można również nadpisać, używając atrybutu NodeCategory w klasie lub w konstruktorze, jak pokazano poniżej.

Węzeł będzie teraz znajdował się w obszarze dodatków w ścieżce:

ZeroTouch

Biblioteki ZeroTouch są domyślnie organizowane w oparciu o strukturę klas.

Węzeł będzie zlokalizowany w obszarze dodatków w ścieżce:

Położenie struktury klas można również nadpisać za pomocą pliku XML dostosowywania dodatku Dynamo.

  • Plik XML musi mieć odpowiednią nazwę i być umieszczony w folderze extra pakietu

    • PackageName_DynamoCustomization.xml

Węzły niestandardowe

Węzły niestandardowe są organizowane na podstawie wartości Category Name określonej podczas ich tworzenia (za pomocą nowego okna dialogowego Węzeł niestandardowy).

OSTRZEŻENIE! Użycie zapisu kropkowego w nazwach lub kategoriach węzłów spowoduje utworzenie dodatkowych podkategorii zagnieżdżonych. Kropka . będzie pełnić rolę separatora określającego dodatkową hierarchię. Jest to nowe zachowanie w bibliotece dodatku Dynamo 2.0.

Właściwości węzła niestandardowego

Nazwę kategorii można później zaktualizować w pliku .dyf (XML lub JSON)

Strategie migracji węzłów z pakietów

Gdy autor pakietu decyduje się zmienić nazwę wcześniej istniejącego węzła w nowej wersji, powinien zapewnić mechanizmy migracji wykresów zawierających węzły o starych nazwach. Można to zrealizować na następujące sposoby...

Węzły ZeroTouch używają pliku Namespace.Migrations.XML znajdującego się w folderze pakietów bin, na przykład:

MyZeroTouchLib.MyNodes.SayHello na MyZeroTouchLib.MyNodes.SayHelloRENAMED

Węzły pochodne NodeModel używają atrybutu AlsoKnownAs klasy, na przykład:

SampleLibraryUI.Examples.DropDownExample na SampleLibraryUI.Examples.DropDownExampleRENAMED

Last updated