Aplicar diseño Árbol inteligente (Diagrama de red)

Resumen

Organiza jerárquicamente las entidades de diagrama y las coloca en un árbol inteligente.

Más información acerca del algoritmo de diseño Árbol de línea inteligente

Precaución:

Si tiene una sesión de edición abierta, debe guardar sus cambios antes de ejecutar esta herramienta. Con ello se garantiza que el diagrama refleje los cambios más recientes aplicados a la topología de red en la base de datos. Si no guarda las ediciones, estas no se reflejarán en el diagrama.

Nota:

Todos los algoritmos de diseño incluyen valores predeterminados para los parámetros. Los valores predeterminados de los parámetros son los que se usan mientras no se especifique otro valor. Si el diagrama de red de entrada se basa en una plantilla para la cual este diseño tiene configurado otro valor de parámetro, se utilizará en su lugar este valor.

Uso

  • Esta herramienta no se admite al trabajar con una conexión de base de datos a una red de servicios o red de trazado de una geodatabase corporativa. Debe usar el servicio de red de servicios o red de trazado publicado relacionado o una red de servicios o red de trazado de una geodatabase móvil o de archivos.

  • La capa de diagrama de red de entrada debe provenir de una red de servicios o una red de trazado de una geodatabase de archivos o móvil o un servicio de diagramas de red.

  • Este algoritmo de diseño ordena jerárquicamente las entidades de diagrama y las coloca en un árbol inteligente de acuerdo con la dirección y las distancias de espaciado especificadas.

  • Si se ha especificado un cruce raíz en el diagrama, el algoritmo de diseño Árbol inteligente genera un árbol inteligente a partir de ese cruce.

    Si se especifican varios cruces raíz en el diagrama, estos cruces raíz se alinean a lo largo del mismo eje, en perpendicular a la dirección del árbol, y aparecen como puntos de inicio diferentes para la rama de árbol del diagrama.

    Si no se especifica ningún cruce raíz, el algoritmo identifica el cruce de diagrama asociado con el índice más bajo de la topología de red y utiliza este cruce como cruce raíz.

  • Plantéese aplicar el diseño en modo asíncrono en el servidor al trabajar en diagramas muy grandes.

Parámetros

EtiquetaExplicaciónTipo de datos
Capa de diagrama de red de entrada

El diagrama de red al que se aplica el diseño.

Diagram Layer
Conservar diseño del contenedor
(Opcional)

Especifica cómo procesará el algoritmo los contenedores.

  • Activado: el algoritmo de diseño se aplicará en el gráfico superior del diagrama, de modo que los contenedores se conservan.
  • Desactivado: el algoritmo de diseño se aplicará tanto en las entidades de contenido como en las entidades sin contenido del diagrama. Esta es la opción predeterminada.

Boolean
Dirección de árbol
(Opcional)

Especifica la dirección del árbol.

  • De izquierda a derechaEl árbol se dibuja de izquierda a derecha. Esta es la opción predeterminada.
  • De derecha a izquierdaEl árbol se dibuja de derecha a izquierda.
  • De abajo arribaEl árbol se dibuja de abajo arriba.
  • De arriba abajoEl árbol se dibuja de arriba abajo.
String
Valores de espaciado interpretados como unidades absolutas en el sistema de coordenadas del diagrama
(Opcional)

Especifica cómo se interpretarán los parámetros que representan distancias.

  • Activado: el algoritmo de diseño interpretará los valores de distancia como unidades lineales.
  • Desactivado: el algoritmo de diseño interpretará los valores de distancia como unidades relativas a una estimación de la media de los tamaños de los cruces de la extensión del diagrama actual. Esta es la opción predeterminada.

Boolean
Entre subárboles
(Opcional)

El espaciado entre dos subárboles vecinos; es decir, el espaciado entre los cruces de diagrama que se visualizan en perpendicular a la dirección del árbol inteligente y pertenecen a otro subárbol. El valor predeterminado está en las unidades del sistema de coordenadas del diagrama. Este parámetro solo se puede usar con unidades absolutas.

Linear Unit
Entre subárboles
(Opcional)

El espaciado entre dos subárboles vecinos; es decir, el espaciado entre los cruces de diagrama que se visualizan en perpendicular a la dirección del árbol inteligente y pertenecen a otro subárbol. El valor predeterminado es 2. Este parámetro solo se puede usar con unidades proporcionales.

Double
Entre cruces perpendicular a la dirección
(Opcional)

El espaciado entre los cruces de diagrama que se visualizan en perpendicular a la dirección del árbol inteligente y pertenecen al mismo nivel de subárbol. El valor predeterminado es de 2 en las unidades del sistema de coordenadas del diagrama. Este parámetro solo se puede usar con unidades absolutas.

Linear Unit
Entre cruces perpendicular a la dirección
(Opcional)

El espaciado entre los cruces de diagrama que se visualizan en perpendicular a la dirección del árbol inteligente y pertenecen al mismo nivel de subárbol. El valor predeterminado es 2. Este parámetro solo se puede usar con unidades proporcionales.

Double
Entre cruces a lo largo de la dirección
(Opcional)

El espaciado entre los cruces de diagrama que se muestran a lo largo de la dirección del árbol inteligente. El valor predeterminado es de 2 en las unidades del sistema de coordenadas del diagrama. Este parámetro solo se puede usar con unidades absolutas.

Linear Unit
Entre cruces a lo largo de la dirección
(Opcional)

El espaciado entre los cruces de diagrama que se muestran a lo largo de la dirección del árbol inteligente. El valor predeterminado es 2. Este parámetro solo se puede usar con unidades proporcionales.

Double
Entre gráficos inconexos
(Opcional)

El espaciado mínimo que separará las entidades pertenecientes a gráficos inconexos si el diagrama contiene este tipo de gráficos. Este parámetro se usa con unidades absolutas. El valor predeterminado es de 4 en las unidades del sistema de coordenadas del diagrama.

Linear Unit
Entre gráficos inconexos
(Opcional)

El espaciado mínimo que separará las entidades pertenecientes a gráficos inconexos si el diagrama contiene este tipo de gráficos. Este parámetro se usa con unidades proporcionales. El valor predeterminado es 4.

Double
Bordes de la visualización ortogonal
(Opcional)
Boolean
Posición relativa del punto de corte (%)
(Opcional)

La posición relativa del punto de corte que se insertará a lo largo de los ejes de diagrama cuando Tipo de visualización del eje está definido como Ejes regulares (edge_display_type = "REGULAR_EDGES" en Python) o Tipo de visualización del eje está definido como Ejes ortogonales (edge_display_type = "ORTHOGONAL_EDGES" en Python). Se trata de un porcentaje de entre 0 y 100.

  • Con un valor de 0 en Posición relativa de punto de corte (%), el punto de corte se posiciona en la coordenada x del cruce de origen del eje y la coordenada y del cruce de destino del eje si se trata de un árbol horizontal. Se posiciona en la coordenada y del cruce de origen del eje y en la coordenada x del cruce de destino del eje si se trata de un árbol vertical.
  • Con un valor de 100 en Posición relativa de punto de corte (%), no se inserta ningún punto de corte en los ejes del diagrama; todos los ejes del diagrama se conectan directamente a sus cruces de origen y destino.
  • Con un valor N de entre 0 y 100 en Posición relativa de punto de corte (%), el punto de corte se posiciona en el N% de la longitud del segmento [XY], siendo X la coordenada x del cruce de origen del eje e Y la coordenada y del cruce de destino del eje si se trata de un árbol horizontal. Se posiciona en el N% de la longitud del segmento [YX], siendo Y la coordenada y del cruce de origen del eje y X la coordenada x del cruce de destino del eje si se trata de un árbol vertical.

La posición relativa de los dos puntos de inflexión que se insertarán a lo largo de los ejes de diagrama para calcular la geometría de los ejes curvados si el Tipo de visualización del eje está definido como Ejes curvados (edge_display_type = "CURVED_EDGES" en Python). Se trata de un porcentaje de entre 15 y 40. Con un valor de N de Posición relativa del punto de corte (%) entre 15 y 40:

  • Siendo X la coordenada x del cruce de origen del eje e Y siendo la coordenada y del cruce de destino del eje para un árbol horizontal:
    • El primer punto de inflexión se posicionará en N % de la longitud del segmento [XY].
    • El segundo punto de inflexión se posicionará en (100 - N) % de la longitud del segmento [XY].
  • Siendo Y la coordenada y del cruce de origen del eje y X siendo la coordenada x del cruce de destino del eje para un árbol vertical:
    • El primer punto de inflexión se colocará en N % de la longitud del segmento [YX].
    • El segundo punto de inflexión se posicionará en (100 - N) % de la longitud del segmento [XY].

Nota:

El concepto de los cruces de origen y destino mencionado anteriormente es relativo a la dirección del árbol; no guarda relación alguna con la topología real de la entidad de eje ni con el objeto de eje en la red.

Double
Tipo de visualización del eje
(Opcional)

Especifica el tipo de visualización de los ejes de diagrama en relación con las ramas del árbol.

  • Ejes regularesTodos los ejes de diagrama relacionados con las ramas del árbol no se visualizarán con ángulos rectos. Esta es la opción predeterminada.
  • Ejes ortogonalesTodos los ejes del diagrama relacionados con las ramas del árbol se visualizaran con ángulos rectos.
  • Ejes curvadosTodos los ejes de diagrama relacionados con las ramas del árbol estarán curvados.
String
Ejecutar en modo asíncrono en el servidor
(Opcional)

Especifica si el algoritmo de diseño se ejecutará de forma asíncrona o sincrónica en el servidor.

  • Activado: el algoritmo de diseño se ejecutará de forma asíncrona en el servidor. Esta opción dedica recursos del servidor a ejecutar el algoritmo de diseño con un tiempo límite más largo. Se recomienda la ejecución asíncrona para diseños que tardan y podrían rebasar el tiempo límite del servidor (por ejemplo, ejes parcialmente superpuestos) y al aplicar diagramas grandes (más de 25.000 entidades).
  • Desactivado: el algoritmo de diseño se ejecutará de forma sincrónica en el servidor. Puede fallar sin completarse si supera el valor de tiempo límite predeterminado de servicio: 600 segundos. Esta es la opción predeterminada.

Boolean
Desplazamiento absoluto
(Opcional)

El desplazamiento que se utilizará para separar los segmentos superpuestos al utilizar unidades absolutas y si Tipo de visualización del eje tiene el valor definido como Ejes ortogonales. El valor no puede rebasar el 10 por ciento del valor más pequeño especificado para los otros parámetros de espaciamiento. El valor predeterminado es 0.

Linear Unit
Desplazamiento proporcional
(Opcional)

El desplazamiento que se utilizará para separar los segmentos superpuestos al utilizar unidades proporcionales y si Tipo de visualización del eje tiene el valor definido como Ejes ortogonales. Es un valor doble que no puede rebasar el 10 por ciento del valor más pequeño especificado para los otros parámetros de espaciamiento. El valor predeterminado es 0.

Double

Salida derivada

EtiquetaExplicaciónTipo de datos
Diagrama de red de salida

La capa de diagrama de red actualizada.

Capa de diagrama

arcpy.nd.ApplySmartTreeLayout(in_network_diagram_layer, {are_containers_preserved}, {tree_direction}, {is_unit_absolute}, {subtree_absolute}, {subtree_proportional}, {perpendicular_absolute}, {perpendicular_proportional}, {along_absolute}, {along_proportional}, {disjoined_graph_absolute}, {disjoined_graph_proportional}, {are_edges_orthogonal}, {breakpoint_position}, {edge_display_type}, {run_async}, {offset_absolute}, {offset_proportional})
NombreExplicaciónTipo de datos
in_network_diagram_layer

El diagrama de red al que se aplica el diseño.

Diagram Layer
are_containers_preserved
(Opcional)

Especifica cómo procesará el algoritmo los contenedores.

  • PRESERVE_CONTAINERSEl algoritmo de diseño se aplicará en el gráfico superior del diagrama, de modo que los contenedores se conservan.
  • IGNORE_CONTAINERSEl algoritmo de diseño se aplicará tanto en las entidades de contenido como en las entidades sin contenido del diagrama. Esta es la opción predeterminada.
Boolean
tree_direction
(Opcional)

Especifica la dirección del árbol.

  • FROM_LEFT_TO_RIGHTEl árbol se dibuja de izquierda a derecha. Esta es la opción predeterminada.
  • FROM_RIGHT_TO_LEFTEl árbol se dibuja de derecha a izquierda.
  • FROM_BOTTOM_TO_TOPEl árbol se dibuja de abajo arriba.
  • FROM_TOP_TO_BOTTOMEl árbol se dibuja de arriba abajo.
String
is_unit_absolute
(Opcional)

Especifica cómo se interpretarán los parámetros que representan distancias.

  • ABSOLUTE_UNITEl algoritmo de diseño interpretará los valores de distancia como unidades lineales.
  • PROPORTIONAL_UNITEl algoritmo de diseño interpretará los valores de distancia como unidades relativas a una estimación de la media de los tamaños de los cruces de la extensión del diagrama actual. Esta es la opción predeterminada.
Boolean
subtree_absolute
(Opcional)

El espaciado entre dos subárboles vecinos; es decir, el espaciado entre los cruces de diagrama que se visualizan en perpendicular a la dirección del árbol inteligente y pertenecen a otro subárbol. El valor predeterminado está en las unidades del sistema de coordenadas del diagrama. Este parámetro solo se puede usar con unidades absolutas.

Linear Unit
subtree_proportional
(Opcional)

El espaciado entre dos subárboles vecinos; es decir, el espaciado entre los cruces de diagrama que se visualizan en perpendicular a la dirección del árbol inteligente y pertenecen a otro subárbol. El valor predeterminado es 2. Este parámetro solo se puede usar con unidades proporcionales.

Double
perpendicular_absolute
(Opcional)

El espaciado entre los cruces de diagrama que se visualizan en perpendicular a la dirección del árbol inteligente y pertenecen al mismo nivel de subárbol. El valor predeterminado es de 2 en las unidades del sistema de coordenadas del diagrama. Este parámetro solo se puede usar con unidades absolutas.

Linear Unit
perpendicular_proportional
(Opcional)

El espaciado entre los cruces de diagrama que se visualizan en perpendicular a la dirección del árbol inteligente y pertenecen al mismo nivel de subárbol. El valor predeterminado es 2. Este parámetro solo se puede usar con unidades proporcionales.

Double
along_absolute
(Opcional)

El espaciado entre los cruces de diagrama que se muestran a lo largo de la dirección del árbol inteligente. El valor predeterminado es de 2 en las unidades del sistema de coordenadas del diagrama. Este parámetro solo se puede usar con unidades absolutas.

Linear Unit
along_proportional
(Opcional)

El espaciado entre los cruces de diagrama que se muestran a lo largo de la dirección del árbol inteligente. El valor predeterminado es 2. Este parámetro solo se puede usar con unidades proporcionales.

Double
disjoined_graph_absolute
(Opcional)

El espaciado mínimo que separará las entidades pertenecientes a gráficos inconexos si el diagrama contiene este tipo de gráficos. Este parámetro se usa con unidades absolutas. El valor predeterminado es de 4 en las unidades del sistema de coordenadas del diagrama.

Linear Unit
disjoined_graph_proportional
(Opcional)

El espaciado mínimo que separará las entidades pertenecientes a gráficos inconexos si el diagrama contiene este tipo de gráficos. Este parámetro se usa con unidades proporcionales. El valor predeterminado es 4.

Double
are_edges_orthogonal
(Opcional)

Especifica cómo se visualizarán los ejes de diagrama relacionados con las ramas del árbol.

Heredado:

Este parámetro está obsoleto desde ArcGIS Pro 3.4. Se ignora sistemáticamente con independencia de su valor si se especifica el parámetro edge_display_type. Sin embargo, para mantener la compatibilidad con ArcGIS Pro 2.1, permanece habilitado si no se especifica el parámetro edge_display_type.

  • ORTHOGONAL_EDGESTodos los ejes del diagrama relacionados con las ramas del árbol se visualizaran con ángulos rectos.
  • SLANTED_EDGESTodos los ejes de diagrama relacionados con las ramas del árbol no se visualizarán con ángulos rectos. Esta es la opción predeterminada.
Boolean
breakpoint_position
(Opcional)

La posición relativa del punto de corte que se insertará a lo largo de los ejes de diagrama cuando Tipo de visualización del eje está definido como Ejes regulares (edge_display_type = "REGULAR_EDGES" en Python) o Tipo de visualización del eje está definido como Ejes ortogonales (edge_display_type = "ORTHOGONAL_EDGES" en Python). Se trata de un porcentaje de entre 0 y 100.

  • Con un valor de 0 en Posición relativa de punto de corte (%), el punto de corte se posiciona en la coordenada x del cruce de origen del eje y la coordenada y del cruce de destino del eje si se trata de un árbol horizontal. Se posiciona en la coordenada y del cruce de origen del eje y en la coordenada x del cruce de destino del eje si se trata de un árbol vertical.
  • Con un valor de 100 en Posición relativa de punto de corte (%), no se inserta ningún punto de corte en los ejes del diagrama; todos los ejes del diagrama se conectan directamente a sus cruces de origen y destino.
  • Con un valor N de entre 0 y 100 en Posición relativa de punto de corte (%), el punto de corte se posiciona en el N% de la longitud del segmento [XY], siendo X la coordenada x del cruce de origen del eje e Y la coordenada y del cruce de destino del eje si se trata de un árbol horizontal. Se posiciona en el N% de la longitud del segmento [YX], siendo Y la coordenada y del cruce de origen del eje y X la coordenada x del cruce de destino del eje si se trata de un árbol vertical.

La posición relativa de los dos puntos de inflexión que se insertarán a lo largo de los ejes de diagrama para calcular la geometría de los ejes curvados si el Tipo de visualización del eje está definido como Ejes curvados (edge_display_type = "CURVED_EDGES" en Python). Se trata de un porcentaje de entre 15 y 40. Con un valor de N de Posición relativa del punto de corte (%) entre 15 y 40:

  • Siendo X la coordenada x del cruce de origen del eje e Y siendo la coordenada y del cruce de destino del eje para un árbol horizontal:
    • El primer punto de inflexión se posicionará en N % de la longitud del segmento [XY].
    • El segundo punto de inflexión se posicionará en (100 - N) % de la longitud del segmento [XY].
  • Siendo Y la coordenada y del cruce de origen del eje y X siendo la coordenada x del cruce de destino del eje para un árbol vertical:
    • El primer punto de inflexión se colocará en N % de la longitud del segmento [YX].
    • El segundo punto de inflexión se posicionará en (100 - N) % de la longitud del segmento [XY].

Nota:

El concepto de los cruces de origen y destino mencionado anteriormente es relativo a la dirección del árbol; no guarda relación alguna con la topología real de la entidad de eje ni con el objeto de eje en la red.

Double
edge_display_type
(Opcional)

Especifica el tipo de visualización de los ejes de diagrama en relación con las ramas del árbol.

  • REGULAR_EDGESTodos los ejes de diagrama relacionados con las ramas del árbol no se visualizarán con ángulos rectos. Esta es la opción predeterminada.
  • ORTHOGONAL_EDGESTodos los ejes del diagrama relacionados con las ramas del árbol se visualizaran con ángulos rectos.
  • CURVED_EDGESTodos los ejes de diagrama relacionados con las ramas del árbol estarán curvados.
String
run_async
(Opcional)

Especifica si el algoritmo de diseño se ejecutará de forma asíncrona o sincrónica en el servidor.

  • RUN_ASYNCHRONOUSLYEl algoritmo de diseño se ejecutará de forma asíncrona en el servidor. Esta opción dedica recursos del servidor a ejecutar el algoritmo de diseño con un tiempo límite más largo. Se recomienda la ejecución asíncrona para diseños que tardan y podrían rebasar el tiempo límite del servidor (por ejemplo, ejes parcialmente superpuestos) y al aplicar diagramas grandes (más de 25.000 entidades).
  • RUN_SYNCHRONOUSLYEl algoritmo de diseño se ejecutará de forma sincrónica en el servidor. Puede fallar sin completarse si supera el valor de tiempo límite predeterminado de servicio: 600 segundos. Esta es la opción predeterminada.
Boolean
offset_absolute
(Opcional)

El desplazamiento que se utilizará para separar los segmentos superpuestos con is_unit_absolute = "ABSOLUTE_UNIT" y edge_display_type = "ORTHOGONAL_EDGES". El valor no puede rebasar el 10 por ciento del valor más pequeño especificado para los otros parámetros de espaciamiento. El valor predeterminado es 0.

Linear Unit
offset_proportional
(Opcional)

El desplazamiento que se utilizará para separar los segmentos superpuestos con is_unit_absolute = "PROPORTIONAL_UNIT" y edge_display_type = "ORTHOGONAL_EDGES". Es un valor doble que no puede rebasar el 10 por ciento del valor más pequeño especificado para los otros parámetros de espaciamiento. El valor predeterminado es 0.

Double

Salida derivada

NombreExplicaciónTipo de datos
out_network_diagram_layer

La capa de diagrama de red actualizada.

Capa de diagrama

Muestra de código

Ejemplo de ApplySmartTreeLayout (ventana de Python)

Este ejemplo aplica el algoritmo de diseño Árbol inteligente al diagrama denominado Diagrama temporal.

import arcpy
arcpy.ApplySmartTreeLayout_nd("Temporary Diagram", "PRESERVE_CONTAINERS", 
                              "FROM_LEFT_TO_RIGHT", "PROPORTIONAL_UNIT", 
                              "", 8, "", 5, "", 5, "", 15, "", 70, 
                              "REGULAR_EDGES", "RUN_SYNCHRONOUSLY")

Entornos

Esta herramienta no utiliza ningún entorno de geoprocesamiento.

Información de licenciamiento

  • Basic: No
  • Standard: Sí
  • Advanced: Sí

Temas relacionados