JTree - TreePath - TreeNode

Aus Byte-Welt Wiki
Zur Navigation springenZur Suche springen

Bei der Arbeit mit JTree und TreeModel kommt man zwangsläufig mit der Klasse TreePath in Berührung. Doch, was ist TreePath? Wie kann er erzeugt bzw. aufgebaut werden?

Was ist ein TreePath?

Stellen wir uns eine Ameise vor, die auf einem Blatt einer Linde sitzt und den Morgentau einsammelt. Die Ameise möchte gerne ihrer Königin, die an der Wurzel des Baumes lebt, den Tau bringen.

TreePath ist nun eine Repräsentation des direkten Pfades, den die Ameise ausgehend von ihrem Blatt des Baums bis zur Wurzel entlang laufen muss, um zu ihrer Königin zu gelangen.

Mit anderen Worten und auf den JTree übertragen, stellt TreePath ein Array von Objekten dar, die den Pfad zu einem Knoten in einer Baumstruktur eindeutig identifizieren. Die Elemente des Arrays sind so angeordnet, dass die Wurzel das erste Element (Index 0) des Arrays ist.

Beispielsweise wird eine Datei im Dateisystem anhand des Arrays der übergeordneten Verzeichnisse und des Dateinamens eindeutig identifiziert. Der Pfad /wurzel/stamm/ast/zweig/blatt kann durch ein TreePath-Objekt dargestellt werden new Object[]{"wurzel", "stamm", "ast", "zweig", "blatt"}).

TreePath wird von JTree und verwandten Klassen umfassend verwendet. Beispielsweise repräsentiert JTree die Auswahl als Array von TreePaths. Wenn JTree mit DefaultTreeModel gekoppelt ist, sind die Elemente des Pfads TreeNodes.

TreePath erzeugen

Der JTree bietet mit der Methode getSelectionPath() bereits eine Möglichkeit an, den TreePath des gerade selektierten Knotens zu erhalten. Wenn das TreeModel den TreePath aber selbst ermitteln will/muss, kann es auch die TreeNodes durchlaufen und so den "Weg" von einem Knoten zur Wurzel des Baumes aufzeichnen.

Die folgende getTreePath()-Methode könnte in einem realen TreeModel-Typ implementiert sein. Sie kann dazu dienen, ein TreePath-Objekt für die Übergabe an die TreeModelEvent verarbeitenden fireTreeXXX()-Methoden zu erzeugen.

TreePath aus einem TreeNode erzeugen

    /**
     * Erzeugt aus dem übergebenen TreeNode ein TreePath-Objekt.
     *
     * @param treeNode der TreeNode, von dem aus ein Pfad bis zum Wurzelknoten
     * erzeugt werden soll
     * @return das erzeugte TreePath-Objekt
     */
    public TreePath getTreePath(TreeNode treeNode) {
       List<Object> nodes = new ArrayList<>();
       do {
          nodes.add(0, treeNode);
       }
       while ((treeNode = treeNode.getParent()) != null);

       return nodes.isEmpty() ? null : new TreePath(nodes.toArray());
    }

Siehe auch