`

JTree用法及JTree使用经验总结

 
阅读更多

××××××××××××××××××××××××××××××××××××××××××××××

在实际开发过程中会经常使用JTree组件,平时会遇到这样或那样的问题,在此将偶得一点经验写下来,与大家共享,希望对大家有所帮助。

private JTree jtNetDevice;//数组件申明
private JScrollPane jspTree;//滚动面板申明


1、初始化
    DefaultMutableTreeNode rootNode = new DefaultMutableTreeNode("root");
    jtNetDevice = new JTree(rootNode);
    jtNetDevice.setAutoscrolls(true);
    getTreeSelectionModel().setSelectionMode(TreeSelectionModel.SINGLE_TREE_SELECTION);//设置单选模式
    jspTree = new JScrollPane();
    jspTree.getViewport().add(jtNetDevice, null);

2、三个经常使用的取值函数
  private DefaultTreeModel getTreeModel(){
    return (DefaultTreeModel)jtNetDevice.getModel();
  }

  private DefaultMutableTreeNode getRootNode(){
    return (DefaultMutableTreeNode)getTreeModel().getRoot();
  }
 
  private TreeSelectionModel getTreeSelectionModel(){
    return jtNetDevice.getSelectionModel();
  }

3、根据node得到path:
  TreePath visiblePath = new TreePath(getTreeModel().getPathToRoot(node));

4、根据Path展开到该节点
  jtNetDevice.makeVisible(visiblePath);

5、根据path设定该节点选定
  jtNetDevice.setSelectionPath(visiblePath);

6、选中节点的方法
  首先,根据节点得到树路径,其中chosen为需要选中的节点
  TreePath visiblePath = new TreePath( ( (DefaultTreeModel) jtNetDevice.getModel()).
                                        getPathToRoot(chosen));
  然后根据Path选中该节点
  jtNetDevice.setSelectionPath(visiblePath);

7、滚动到可见位置
  jtNetDevice.scrollPathToVisible(visiblePath);

8、给JTree添加右键弹出菜单
  void jtNetDevice_mouseReleased(MouseEvent e) {
    if (e.isPopupTrigger()) {
      jPopupMenu1.show(e.getComponent(), e.getX(), e.getY());//弹出右键菜单
    }
  }

9、关于JTree的展开
   // If expand is true, expands all nodes in the tree.
   // Otherwise, collapses all nodes in the tree.
   public void expandAll(JTree tree, boolean expand) {
       TreeNode root = (TreeNode)tree.getModel().getRoot();
  
       // Traverse tree from root
       expandAll(tree, new TreePath(root), expand);
   }
   private void expandAll(JTree tree, TreePath parent, boolean expand) {
       // Traverse children
       TreeNode node = (TreeNode)parent.getLastPathComponent();
       if (node.getChildCount() >= 0) {
           for (Enumeration e=node.children(); e.hasMoreElements(); ) {
               TreeNode n = (TreeNode)e.nextElement();
               TreePath path = parent.pathByAddingChild(n);
               expandAll(tree, path, expand);
           }
       }
  
       // Expansion or collapse must be done bottom-up
       if (expand) {
           tree.expandPath(parent);
       } else {
           tree.collapsePath(parent);
       }
   }

10、如何遍历JTree
   // 创建树
   JTree tree = new JTree();
  
   // 添加树节点......
  
   // 遍历所有节点
   visitAllNodes(tree);
  
   // 仅遍历展开的节点
   visitAllExpandedNodes(tree);
  
   // Traverse all nodes in tree
   public void visitAllNodes(JTree tree) {
       TreeNode root = (TreeNode)tree.getModel().getRoot();
       visitAllNodes(root);
   }
   public void visitAllNodes(TreeNode node) {
       // node is visited exactly once
       process(node);
  
       if (node.getChildCount() >= 0) {
           for (Enumeration e=node.children(); e.hasMoreElements(); ) {
               TreeNode n = (TreeNode)e.nextElement();
               visitAllNodes(n);
           }
       }
   }
  
   // Traverse all expanded nodes in tree
   public void visitAllExpandedNodes(JTree tree) {
       TreeNode root = (TreeNode)tree.getModel().getRoot();
       visitAllExpandedNodes(tree, new TreePath(root));
   }
   public void visitAllExpandedNodes(JTree tree, TreePath parent) {
       // Return if node is not expanded
       if (!tree.isVisible(parent)) {
           return;
       }
  
       // node is visible and is visited exactly once
       TreeNode node = (TreeNode)parent.getLastPathComponent();
       process(node);
  
       // Visit all children
       if (node.getChildCount() >= 0) {
           for (Enumeration e=node.children(); e.hasMoreElements(); ) {
               TreeNode n = (TreeNode)e.nextElement();
               TreePath path = parent.pathByAddingChild(n);
               visitAllExpandedNodes(tree, path);
           }
       }
   }

 

http://www.blogjava.net/wangxinsh55/archive/2006/04/04/39219.html

分享到:
评论

相关推荐

    JTree用法及JTree使用经验总结及源码

    JTree用法及JTree使用经验总结(吐血推荐) 1、初始化 2、三个经常使用的取值函数 3、根据node得到path:4、根据Path展开到该节点 5、根据path设定该节点选定 6、选中节点的方法 7、滚动到可见位置 8、给JTree添加右键...

    JTree组件资料

    JTree的使用经验与总结 - **性能优化**: 当树结构非常大时,使用懒加载策略以提高性能。 - **自定义节点**: 可以通过继承`DefaultMutableTreeNode`并重写相关方法来自定义节点行为。 - **节点遍历**: 能够使用`...

    swing界面设计之JTree

    #### (四) JTree的使用方法 **JTreeDemo.java源程序**:示例代码展示了如何创建并使用JTree。 - **经验汇总**:列举了一系列实用技巧,包括初始化、节点选取、路径操作等方面。 #### (五) JTree右键菜单实现编辑、...

    demo.rar_DEMO_日记本

    这些基本操作的实现通常涉及到文件操作,例如使用File类的方法来检查文件是否存在、打开文件读取内容,以及删除文件。同时,为了确保数据的安全,程序可能还包含了错误处理机制,如检查文件是否正确关闭,防止数据...

    Java课程实训项目及实训报告

    在报告中,应阐述选择特定技术和方法的原因,描述遇到的问题及解决策略,同时反思项目实施过程中的经验教训,以便于自我提升。 通过这个Java实训项目,学生不仅能巩固课堂所学,还能锻炼问题解决能力和团队协作技巧...

    自己写的cmm语法分析器

    通过这个项目,你可以学习到如何从零开始构建一个完整的解析器,了解编译器前端的各个环节,同时还能掌握JTree库的使用,这对于提升编程技能和理解编译原理都大有裨益。 总的来说,编写自己的CMM语法分析器是一个既...

    Design Pattern In Java.pdf

    设计模式是软件开发中的一种最佳实践,它总结了在特定情境下解决常见问题的经验和方法,为面向对象编程提供了可复用的设计解决方案。本书是Java开发者深入理解设计模式的重要参考资料。 1. 创建型模式(Creational ...

    java swing权威指南

    - **总结**:本书全面介绍了 Java Swing 的各个方面,不仅适合初学者入门学习,也适合有经验的开发者深入探索。 - **展望**:虽然近年来 JavaFX 和其他现代 GUI 框架逐渐兴起,但 Swing 仍然因其成熟稳定、功能...

    Java图形界面开发-awt、swing、swt

    ### Java图形界面开发知识点 #### 1. 概述与发展历程 ...无论是初学者还是有经验的开发者,都应该熟悉这些工具包的特点和应用场景,以便能够根据项目需求选择最合适的工具来构建高质量的图形界面应用程序。

Global site tag (gtag.js) - Google Analytics