
Я следовал решению, основанному на лесе, из этого поста.Создание (простого) дерева каталоговдля создания структуры каталогов. Прямо к каждому файлу и имени я хочу добавить его полный путь. Полные пути также должны быть выровнены по левому краю. Я придумал это грязное решение:
\documentclass{standalone}
\usepackage{forest}
\usetikzlibrary{positioning}
\begin{document}
\begin{forest}
for tree={
font=\ttfamily,
grow'=0,
child anchor=west,
parent anchor=south,
anchor=west,
calign=first,
s sep=6pt,
inner sep=0pt,
edge path={
\noexpand\path [draw, \forestoption{edge}]
(!u.south west) +(6pt,0) |- (.child anchor)\forestoption{edge label};
},
before typesetting nodes={
if n=1
{insert before={[,phantom]}}
{}
},
fit=band,
before computing xy={l=5mm},
}
[a,name=a
[b
[c
[d]
]
]
[e
[f]
[b]
]
]
%
\node[right of=a,node distance=2cm] (desc) {\tt /a};
\node[below=13pt of desc.west,anchor=west] (desc) {\tt /a/b};
\node[below=13pt of desc.west,anchor=west] (desc) {\tt /a/b/c};
\node[below=13pt of desc.west,anchor=west] (desc) {\tt /a/b/c/d};
\node[below=12pt of desc.west,anchor=west] (desc) {\tt /a/e};
\node[below=13pt of desc.west,anchor=west] (desc) {\tt /a/e/f};
\node[below=13pt of desc.west,anchor=west] (desc) {\tt /a/e/b};
\end{forest}
\end{document}
Это отображается так:
Выглядит нормально, но мне бы хотелось найти простое решение, которое позволит избежать жесткого кодирования расстояний между полными путями.
решение1
Я предлагаю несколько упростить ваше дерево, используя forked edge
, с fork sep=0pt
. (Обратите внимание, что для этого требуется \usepackage[edges]{forest}
.) Я включил каждое описание пути как новый дочерний узел, затем использовал if n children=0{no edge, tier=desc}{l-=4mm}
для предотвращения рисования этих последних ребер и сохранения их выравнивания в l
измерении (для чего и tier
используется). Если n children
≠0, то l
измерение сокращается на 4mm
. Вы также можете сократить (на ту же или другую величину), если хотите, чтобы описание пути было ближе к дереву.
\documentclass{article}
\usepackage[edges]{forest}
\begin{document}
\begin{forest}
for tree={
font=\ttfamily,
grow'=0,
anchor=west,
calign=first,
s sep=6pt,
inner sep=0pt,
forked edge,
fork sep=0pt,
l sep=3mm,
if n children=0{no edge, tier=desc}{l-=4mm}
}
[a
[/a]
[b
[/a/b]
[c
[/a/b/c]
[d
[/a/b/c/d]
]
]
]
[e
[/a/e]
[f
[/a/e/f]
]
[b
[/a/e/b]
]
]
]
\end{forest}
\end{document}