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.
Węzeł będzie zlokalizowany w obszarze dodatków w ścieżce:
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
pakietuPackageName_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.
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