• 追加された行はこの色です。
  • 削除された行はこの色です。
---
category: swing
folder: ExpandAllNodes
title: JTreeのノードを展開・折り畳み
tags: [JTree, TreeNode, TreePath]
author: aterai
pubdate: 2007-05-07T17:11:21+09:00
description: JTreeのすべてのノードに対して、展開、折り畳みを行います。
image: https://lh5.googleusercontent.com/_9Z4BYR88imo/TQTMS3T9nvI/AAAAAAAAAY8/ooi4QMbp6fA/s800/ExpandAllNodes.png
---
* 概要 [#summary]
`JTree`のすべてのノードに対して、展開、折り畳みを行います。

#download(https://lh5.googleusercontent.com/_9Z4BYR88imo/TQTMS3T9nvI/AAAAAAAAAY8/ooi4QMbp6fA/s800/ExpandAllNodes.png)

* サンプルコード [#sourcecode]
#code(link){{
//@see http://www.rgagnon.com/javadetails/java-0210.html
//Expand or collapse a JTree - Real's Java How-to
private void expandAll(JTree tree) {
  int row = 0;
  while (row < tree.getRowCount()) {
    tree.expandRow(row);
    row++;
  }
}
private void collapseAll(JTree tree) {
  int row = tree.getRowCount() - 1;
  while (row >= 0) {
    tree.collapseRow(row);
    row--;
  }
}

private void visitAll(JTree tree, TreePath parent, boolean expand) {
  TreeNode node = (TreeNode) parent.getLastPathComponent();
  //children(node).forEach(n -> visitAll(tree, parent.pathByAddingChild(n), expand));
  if (!node.isLeaf() && node.getChildCount() >= 0) {
    Enumeration e = node.children();
    Enumeration<?> e = node.children();
    while (e.hasMoreElements()) {
      TreeNode n = (TreeNode) e.nextElement();
      TreePath path = parent.pathByAddingChild(n);
      visitAll(tree, path, expand);
      visitAll(tree, parent.pathByAddingChild(e.nextElement()), expand);
    }
  }
  if (expand) {
    tree.expandPath(parent);
  } else {
    tree.collapsePath(parent);
  }
}

//private static Stream<TreeNode> children(TreeNode node) {
//  return Collections.list((Enumeration<?>) node.children())
//    .stream().filter(TreeNode.class::isInstance).map(TreeNode.class::cast);
//}
}}

* 解説 [#explanation]
- `expandAll(A)`
-- `JTree`をリストとみなして`expandAll`では先頭から順番に`JTree#expandRow(int)`メソッドを実行
-- ループは全展開された時の`JTree`の行数だけ繰り返す

- `collapseAll(A)`
-- 末尾から順番に`JTree#collapseRow(int)`メソッドを実行し、表示されているすべてのノードを折り畳む
-- 子ノードは展開されているが、親ノードが折り畳まれている場合、その非表示となっている子ノードに対しては折り畳みを実行しない

- `expandAll(B)`
-- `visitAll(tree, new TreePath(root), true);`
-- 再帰的に`TreePath`を辿って、展開(`JTree#expandPath(TreePath)`メソッド)を実行

- `collapseAll(B)`
-- `visitAll(tree, new TreePath(root), false);`
-- 再帰的に`TreePath`を辿って、折り畳み(`JTree#collapsePath(TreePath)`メソッド)を実行

* 参考リンク [#reference]
//- %%[http://www.exampledepot.com/egs/javax.swing.tree/ExpandAll.html Expanding or Collapsing All Nodes in a JTree Component (Java Developers Almanac Example)]%%
- [http://www.rgagnon.com/javadetails/java-0210.html Expand or collapse a JTree - Real's Java How-to]
- [[JTreeのノードを検索する>Swing/SearchBox]]

* コメント [#comment]
#comment
- 解説中のラベル`A`と`B`が、ソースコードとは逆になっていたので、これをソースコードと同じになるよう修正。 -- &user(aterai); &new{2008-02-05 (火) 19:31:53};

#comment