TikZ and PGF Manual
Libraries
76 Tree Library¶
-
TikZ Library trees
\usetikzlibrary{trees} %
LaTeX
and plain
TeX
\usetikzlibrary[trees] % ConTeXt
This packages defines styles to be used when drawing trees.
76.1 Growth Functions¶
The package trees defines two new growth functions. They are installed using the following options:
-
/tikz/grow via three points=one child at (⟨x⟩ ) and two children at (⟨y⟩) and (⟨z⟩)(no default) ¶
This option installs a growth function that works as follows: If a parent node has just one child, this child is placed at ⟨x⟩. If the parent node has two children, these are placed at ⟨y⟩ and ⟨z⟩. If the parent node has more than two children, the children are placed at points that are linearly extrapolated from the three points ⟨x⟩, ⟨y⟩, and ⟨z⟩. In detail, the position is \(x + \frac {n-1}{2}(y-x) + (c-1)(z-y)\), where \(n\) is the number of children and \(c\) is the number of the current child (starting with \(1\)).
The net effect of all this is that if you have a certain “linear arrangement” in mind and use this option to specify the placement of a single child and of two children, then any number of children will be placed correctly.
Here are some arrangements based on this growth function. We start with a simple “above” arrangement:
The next arrangement places children above, but “grows only to the right”.
In the final arrangement, the children are placed along a line going down and right.
These examples should make it clear how you can create new styles to arrange your children along a line.
-
/tikz/grow cyclic(no value) ¶
-
/tikz/sibling angle=⟨angle⟩(no default) ¶
This style causes the children to be arranged “on a circle”. For this, the children are placed at distance \tikzleveldistance from the parent node, but not on a straight line, but on points on a circle. Instead of a sibling distance, there is a sibling angle that denotes the angle between two given children.
Sets the angle between siblings in the grow cyclic style.
Note that this function will rotate the coordinate system of the children to ensure that the grandchildren will grow in the right direction.
-
/tikz/clockwise from=⟨angle⟩(no default) ¶
This option also causes children to be arranged on a circle. However, the rule for placing children is simpler than with the grow cyclic style: The first child is placed at ⟨angle⟩ at a distance of \tikzleveldistance. The second child is placed at the same distance from the parent, but at angle ⟨angle⟩\({}-{}\)\tikzsiblingangle. The third child is displaced by another \tikzsiblingangle in a clockwise fashion, and so on.
Note that this function will not rotate the coordinate system.
-
/tikz/counterclockwise from=⟨angle⟩(no default) ¶
Works the same way as clockwise from, but sibling angles are added instead of subtracted.
76.2 Edges From Parent¶
The following styles can be used to modify how the edges from parents are drawn:
-
/tikz/edge from parent fork down(style, no value) ¶
This style will draw a line from the parent downwards (for half the level distance) and then on to the child using only horizontal and vertical lines.
-
/tikz/edge from parent fork right(style, no value) ¶
This style behaves similarly, only it will first draw its edge to the right.
-
/tikz/edge from parent fork left(style, no value) ¶
Behaves similarly to the previous styles.
-
/tikz/edge from parent fork up(style, no value) ¶
Behaves similarly to the previous styles.