TITLE:JTreeのノードを検索する
Posted by terai at 2009-01-12

JTreeのノードを検索する

JTreeを検索して、一致するアイテムを選択します。
  • category: swing folder: SearchBox title: JTreeのノードを検索する tags: [JTree, TreeModel, TreePath, TreeNode] author: aterai pubdate: 2009-01-12T18:57:42+09:00 description: JTreeを検索して、一致するアイテムを選択します。 image: https://lh5.googleusercontent.com/_9Z4BYR88imo/TQTSs3gdysI/AAAAAAAAAjM/r_j-mrb83aU/s800/SearchBox.png

概要

JTreeを検索して、一致するアイテムを選択します。

#screenshot

サンプルコード

#spanend
#spandel
private static void searchTree(JTree tree, TreePath path, String q) {
#spanend
  TreeNode node = (TreeNode)path.getLastPathComponent();
  if(node==null) return;
  if(node.toString().equals(q))
    tree.addSelectionPath(path);
  if(!node.isLeaf() && node.getChildCount()>=0) {
    Enumeration e = node.children();
    while(e.hasMoreElements())
      searchTree(tree, path.pathByAddingChild(e.nextElement()), q);
#spanadd
* サンプルコード [#sourcecode]
#spanend
#spanadd
#code(link){{
#spanend
#spanadd
protected static void searchTree(
#spanend
    JTree tree, TreePath path, String q,
    List<TreePath> rollOverPathLists) {
  Object o = path.getLastPathComponent();
  if (o instanceof TreeNode) {
    TreeNode node = (TreeNode) o;
    if (node.toString().startsWith(q)) {
      rollOverPathLists.add(path);
      tree.expandPath(path.getParentPath());
    }
    if (!node.isLeaf()) {
      // Java 9: Enumeration<TreeNode> e = node.children();
      Enumeration<?> e = node.children();
      while (e.hasMoreElements()) {
        searchTree(tree, path.pathByAddingChild(e.nextElement()),
                   q, rollOverPathLists);
      }
    }
  }
}

解説

上記のサンプルでは、選択されたJTreeのノード以下に、検索文字列と一致するノードがあれば、JTree#addSelectionPath(TreePath)メソッドで選択するようになっています。

解説

上記のサンプルでは、選択されたJTreeのノード以下に検索文字列と一致するノードを検索してJTree#addSelectionPath(TreePath)メソッドで選択しています。
Swing - how to get everything in DefaultTreeNodeのAndre_Uhresさんの投稿のように、TreeModelを使って検索する方法もあります。
#spandel
//<blockquote cite="http://forums.sun.com/thread.jspa?messageID=10584331#10584331">
#spanend
#spanadd
// <blockquote cite="https://community.oracle.com/thread/1357454">
#spanend
public void traverse(JTree tree) {
  TreeModel model = tree.getModel();
  Object root;
  if(model != null) {
  if (model != null) {
    root = model.getRoot();
    walk(model,root);
  }else{
    walk(model, root);
  } else {
    System.out.println("Tree is empty.");
  }
}
#spanadd

#spanend
protected void walk(TreeModel model, Object o) {
  int cc = model.getChildCount(o);
  for(int i=0; i < cc; i++) {
  for (int i = 0; i < cc; i++) {
    DefaultMutableTreeNode child = (DefaultMutableTreeNode) model.getChild(o, i);
    if(model.isLeaf(child)) {
    if (model.isLeaf(child)) {
      System.out.println(child);
    }else{
    } else {
      System.out.println(child);
      walk(model, child);
    }
  }
}
#spandel
//<blockquote />
#spanend
#spanadd
// </blockquote>
#spanend

参考リンク

コメント

  • ソースを拝見させていただきましたが, 要素の挿入の箇所がさっぱりわかりません... -- taji
  • 途中で切れてしまい失礼しました. できればどこで挿入しているのか教えていただけませんか? -- taji
    • JTreeのデフォルトコンストラクタがサンプルモデルを持つ JTree を返しているので、%JAVA_HOME%\src.zipを展開して、JTree()を見るのがよいと思います。そこからたどって行けばprotected static TreeModel getDefaultTreeModel()の中で、TreeModelを作って要素を挿入している様子が分かります。 -- terai
      #spanend
      #spanadd
      TreeModel model = tree.getModel();
      #spanend
      #spanadd
      DefaultMutableTreeNode root = (DefaultMutableTreeNode) model.getRoot();
      #spanend
      #spanadd
      Enumeration depth = root.depthFirstEnumeration();
      #spanend
      #spanadd
      while (depth.hasMoreElements()) {
      #spanend
        DefaultMutableTreeNode node = (DefaultMutableTreeNode) depth.nextElement();
        if (node != null && "bananas".equals(node.toString())) {
          TreePath path = new TreePath(node.getPath());
          tree.setSelectionPath(path);
          tree.scrollPathToVisible(path);
          return;
        }
      #spanadd
      }
      #spanend
      #spanadd
      

参考リンク

コメント