TreeElementShapeFunction

TreeElementShapeFunction

is an option for Tree and related functions that specifies a function to use to generate primitives for rendering subtree elements.

Details

  • TreeElementShapeFunction allows specifying the function to generate the shape of the root node of a tree, as well as that of any subtree at positions matching a pattern.
  • The following option settings can be used:
  • Automaticuse the automatic setting for the shape function
    Nonedo not render the subtree element
    "name"a named subtree element shape function
    funca general subtree element shape function
    Allfuncuse subtree element shape function func at all nodes
    TreeCases[pattern]funcuse func at nodes with data matching pattern
    {pos1func1,pos2func2,}use funci at position posi
    {patt1func1,patt2func2,}use funci at positions matching the pattern patti
  • Subtree element style specifications are effectively applied in the order TreeElementStyle, TreeElementStyleFunction and TreeElementShapeFunction, with later specifications overriding earlier ones.
  • TreeElementShapeFunctionfunc specifies that the root node should be rendered with the primitives provided by func[{x,y},data,{w,h}], where {x,y} is the center, data is the data in the root and {w,h} is the width and height.
  • The subtree element function func should render the subtree element primitives in the bounding box {{x-w,x+w},{y-h,y+h}} automatically computed by layout algorithms.

Examples

open allclose all

Basic Examples  (3)

Generate an individual node shape:

Specify a list of node shapes:

Use the same shape function for all nodes:

Scope  (5)

TreeElementShapeFunction Gallery  (4)

Get a list of built-in collections for VertexShapeFunction:

Use built-in settings for TreeElementShapeFunction in the "Basic" collection:

Simple basic shapes:

Common basic shapes:

Use built-in settings for TreeElementShapeFunction in the "Rounded" collection:

Use built-in settings for TreeElementShapeFunction in the "Concave" collection:

Position Specification  (1)

Specify positions using position patterns:

Specify positions using data patterns:

Properties & Relations  (4)

Shapes for subtree elements can be specified by position:

Shapes specified by a subtree take precedence over shapes specified by its ancestors:

A position {i,j,} in a subtree refers to its subtree at relative position {i,j,}:

A relative position {2} at position {1} refers to the global position {1,2}:

In general, a pattern patt applies to subtrees at global positions {i,j,} that match patt:

A list of patterns {patt1,patt2,} applies to relative positions {i,j,} that match patti:

Possible Issues  (1)

Use Inset to render graphics or an image:

TreeElementShape takes graphics or images used for nodes:

Wolfram Research (2022), TreeElementShapeFunction, Wolfram Language function, https://reference.wolfram.com/language/ref/TreeElementShapeFunction.html.

Text

Wolfram Research (2022), TreeElementShapeFunction, Wolfram Language function, https://reference.wolfram.com/language/ref/TreeElementShapeFunction.html.

CMS

Wolfram Language. 2022. "TreeElementShapeFunction." Wolfram Language & System Documentation Center. Wolfram Research. https://reference.wolfram.com/language/ref/TreeElementShapeFunction.html.

APA

Wolfram Language. (2022). TreeElementShapeFunction. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/TreeElementShapeFunction.html

BibTeX

@misc{reference.wolfram_2024_treeelementshapefunction, author="Wolfram Research", title="{TreeElementShapeFunction}", year="2022", howpublished="\url{https://reference.wolfram.com/language/ref/TreeElementShapeFunction.html}", note=[Accessed: 02-January-2025 ]}

BibLaTeX

@online{reference.wolfram_2024_treeelementshapefunction, organization={Wolfram Research}, title={TreeElementShapeFunction}, year={2022}, url={https://reference.wolfram.com/language/ref/TreeElementShapeFunction.html}, note=[Accessed: 02-January-2025 ]}