Caso real de NodeModel (interfaz de usuario personalizada)
Los nodos basados en NodeModel proporcionan una flexibilidad y una eficacia mucho mayores que los nodos Zero-Touch. En este ejemplo, vamos a llevar el nodo de rejilla Zero-Touch al siguiente nivel mediante la adición de un control deslizante integrado que determina aleatoriamente el tamaño del rectángulo.
El control deslizante ajusta la escala de las celdas en relación con su tamaño para que el usuario no tenga que proporcionar un control deslizante con el rango correcto.
El patrón Model-View-Viewmodel
Dynamo se basa en el patrón de arquitectura de software Model-View-Viewmodel (MVVM) para mantener separada la interfaz de usuario del back-end. Al crear nodos Zero-Touch, Dynamo establece el enlace entre los datos de un nodo y su interfaz de usuario. Para crear una interfaz de usuario personalizada, debemos añadir la lógica de enlace de datos.
En un nivel superior, existen dos partes para establecer una relación de modelo-vista en Dynamo, como se indica a continuación:
Una clase
NodeModel
para establecer la lógica del núcleo del nodo (el "modelo").Una clase
INodeViewCustomization
para personalizar cómo se visualiza elNodeModel
(la "vista").
Los objetos NodeModel ya tienen asociada una relación de vista-modelo (NodeViewModel), por lo que podemos centrarnos en el modelo y la vista para la interfaz de usuario personalizada.
Cómo implementar NodeModel
Los nodos NodeModel presentan varias diferencias significativas con respecto a los nodos Zero-Touch que se abordarán en este ejemplo. Antes de pasar a la personalización de la interfaz de usuario, vamos a empezar por generar la lógica de NodeModel.
1. Crear la estructura del proyecto
Un nodo NodeModel solo puede llamar a funciones, por lo que es necesario separar el NodeModel y las funciones en bibliotecas diferentes. El método estándar para los paquetes de Dynamo es crear proyectos independientes para cada uno de ellos. Comience por crear una nueva solución para englobar los proyectos.
Seleccione
File > New > Project
.Seleccione
Other Project Types
para abrir la opción de solución.Seleccione
Blank Solution
.Asigne el nombre
CustomNodeModel
a la solución.Seleccione
Ok
.
Cree dos proyectos de biblioteca de clases de C# en la solución: uno para las funciones y otro para implementar la interfaz de NodeModel.
Haga clic con el botón derecho en la solución y seleccione
Add > New Project
.Seleccione Biblioteca de clases.
Asígnele un nombre a
CustomNodeModel
.Haga clic en
Ok
.Repita el proceso para añadir otro proyecto denominado
CustomNodeModelFunctions
.
A continuación, debemos cambiar el nombre de las bibliotecas de clases que se han creado automáticamente y añadir una al proyecto CustomNodeModel
. La clase GridNodeModel
implementa la clase abstracta NodeModel; GridNodeView
se utiliza para personalizar la vista, y GridFunction
contiene las funciones a las que se debe llamar.
Añada otra clase. Para ello, haga clic con el botón derecho en el proyecto
CustomNodeModel
, seleccioneAdd > New Item...
y, a continuación, elijaClass
.En el proyecto
CustomNodeModel
, necesitamos las clasesGridNodeModel.cs
yGridNodeView.cs
.En el proyecto
CustomNodeModelFunction
, necesitamos una claseGridFunctions.cs
.
Antes de agregar código a las clases, añada los paquetes necesarios para este proyecto. CustomNodeModel
necesitará ZeroTouchLibrary y WpfUILibrary, y CustomNodeModelFunction
solo necesitará ZeroTouchLibrary. WpfUILibrary se utilizará en la personalización de la interfaz de usuario que realizaremos más adelante y ZeroTouchLibrary se empleará para crear geometría. Los paquetes se pueden añadir individualmente para los proyectos. Como estos paquetes presentan dependencias, Core y DynamoServices se instalarán automáticamente.
Haga clic con el botón derecho en un proyecto y seleccione
Manage NuGet Packages
.Instale solo los paquetes necesarios para ese proyecto.
Visual Studio copiará los paquetes NuGet a los que hemos hecho referencia en el directorio de compilación. Esto se puede establecer en "false" (falso) para que no tengamos ningún archivo innecesario en el paquete.
Seleccione paquetes NuGet de Dynamo.
Establezca
Copy Local
en "false" (falso).
2. Heredar la clase NodeModel
Como se ha mencionado anteriormente, el aspecto principal que diferencia un nodo NodeModel de un nodo Zero-Touch es su implementación de la clase NodeModel
. Un nodo NodeModel necesita varias funciones de esta clase y podemos obtenerlas mediante la adición de :NodeModel
después del nombre de la clase.
Copie el código siguiente en GridNodeModel.cs
.
Esto es diferente a los nodos Zero-Touch. Vamos a conocer lo que realiza cada parte.
Especifique los atributos del nodo como nombre, categoría, nombres de puerto de entrada/salida, tipos de puerto de entrada/salida y descripciones.
public class GridNodeModel : NodeModel
es una clase que hereda la claseNodeModel
deDynamo.Graph.Nodes
.public GridNodeModel() { RegisterAllPorts(); }
es un constructor que registra las entradas y las salidas del nodo.BuildOutputAst()
devuelve un AST (árbol de sintaxis abstracta), la estructura necesaria para devolver datos de un nodo NodeModel.AstFactory.BuildFunctionCall()
llama a la función RectangularGrid desdeGridFunctions.cs
.new Func<int, int, double, List<Rectangle>>(GridFunction.RectangularGrid)
especifica la función y sus parámetros.new List<AssociativeNode> { inputAstNodes[0], inputAstNodes[1], sliderValue });
asigna las entradas del nodo a los parámetros de función.AstFactory.BuildNullNode()
genera un nodo nulo si los puertos de entrada no están conectados. Esto se hace para evitar que se muestre una advertencia en el nodo.RaisePropertyChanged("SliderValue")
notifica a la interfaz de usuario cuando cambia el valor del control deslizante.var sliderValue = AstFactory.BuildDoubleNode(SliderValue)
compila un nodo en AST que representa el valor del control deslizanteCambie una entrada a la variable
sliderValue
en la variable functionCallnew List<AssociativeNode> { inputAstNodes[0], sliderValue });
.
3. Llamar a una función
El proyecto CustomNodeModelFunction
se creará en un montaje independiente de CustomNodeModel
para que se pueda llamar a él.
Copie el siguiente código en GridFunction.cs
.
Esta clase de función es muy similar al caso real de rejilla de Zero-Touch con una diferencia:
[IsVisibleInDynamoLibrary(false)]
impide que Dynamo "vea" el siguiente método y clase, ya que la función ya se está llamando desdeCustomNodeModel
.
Al igual que hemos añadido referencias para los paquetes NuGet, CustomNodeModel
deberá hacer referencia a CustomNodeModelFunction
para llamar a la función.
La instrucción "using" de CustomNodeModel estará inactiva hasta que hagamos referencia a la función
Haga clic con el botón derecho en
CustomNodeModel
y seleccioneAdd > Reference
.Seleccione
Projects > Solution
.Active
CustomNodeModelFunction
.Haga clic en
Ok
.
4. Personalizar la vista
Para crear un control deslizante, debemos personalizar la interfaz de usuario mediante la implementación de la interfaz de INodeViewCustomization
.
Copie el siguiente código en GridNodeView.cs
.
public class CustomNodeModelView : INodeViewCustomization<GridNodeModel>
define las funciones necesarias para personalizar la interfaz de usuario.
Una vez configurada la estructura del proyecto, utilice el entorno de diseño de Visual Studio para generar un control de usuario y definir sus parámetros en un archivo .xaml
. En el cuadro de herramientas, añada un control deslizante a <Grid>...</Grid>
.
Haga clic con el botón derecho en
CustomNodeModel
y seleccioneAdd > New Item
.Seleccione
WPF
.Asigne el nombre
Slider
al control de usuario.Haga clic en
Add
.
Copie el siguiente código en Slider.xaml
.
Los parámetros del control deslizante se definen en el archivo
.xaml
. Los atributos Mínimo y Máximo definen el rango numérico de este control deslizante.En
<Grid>...</Grid>
, podemos colocar diferentes controles de usuario desde el cuadro de herramientas de Visual Studio.
Cuando creamos el archivo Slider.xaml
, Visual Studio creó automáticamente un archivo de C# llamado Slider.xaml.cs
que inicializa el control deslizante. Cambie el espacio de nombres de este archivo.
El espacio de nombres debe ser
CustomNodeModel.CustomNodeModel
.
GridNodeModel.cs
define la lógica de cálculo del control deslizante.
5. Configurar como paquete
Antes de generar el proyecto, el último paso es añadir un archivo pkg.json
para que Dynamo pueda leer el paquete.
Haga clic con el botón derecho en
CustomNodeModel
y seleccioneAdd > New Item
.Seleccione
Web
.Seleccione
JSON File
.Asigne al archivo el nombre
pkg.json
.Haga clic en
Add
.
Copie el siguiente código en
pkg.json
.
"name":
determina el nombre del paquete y su grupo en la biblioteca de Dynamo."keywords":
proporciona términos para realizar búsquedas en la biblioteca de Dynamo."node_libraries": []
las bibliotecas asociadas con el paquete.El último paso es generar la solución y publicarla como un paquete de Dynamo. Consulte el capítulo Implementación de paquetes para obtener información sobre cómo crear un paquete local antes de la publicación en línea y cómo generar un paquete directamente desde Visual Studio.
Last updated