позиционирование узлов в лесу

позиционирование узлов в лесу

Я следовал решению, основанному на лесе, из этого поста.Создание (простого) дерева каталоговдля создания структуры каталогов. Прямо к каждому файлу и имени я хочу добавить его полный путь. Полные пути также должны быть выровнены по левому краю. Я придумал это грязное решение:

\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}

Связанный контент