java tree自动展开树

package com.EditJTree;

import java.awt.Dimension;
import java.awt.Rectangle;
import java.util.Enumeration;

import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTree;
import javax.swing.tree.TreeNode;
import javax.swing.tree.TreePath;
  
  	//java tree自动展开树
public class JTreeTest extends JFrame {  
  
    //增加带滚动条容器  
    JScrollPane jScrollPane1 = new JScrollPane();  
  
    //创建树对象  
    JTree treeObj = new JTree();  
  
    public JTreeTest () {  
        try {  
            jbInit();  
        } catch (Exception exception) {  
            exception.printStackTrace();  
        }  
    }
  
    private void jbInit() throws Exception {  
        getContentPane().setLayout(null);  
        setSize(new Dimension(434, 347));  
        setTitle("JTree Test");  
        jScrollPane1.setBounds(new Rectangle(9, 9, 429, 317));  
        this.getContentPane().add(jScrollPane1);  
        expandTree(treeObj);  
        jScrollPane1.getViewport().add(treeObj);  
        setVisible(true);
    }  
  
    /**完全展开一个JTree      
     * @param tree JTree 
    */  
    public static void expandTree(JTree tree) {  
        TreeNode root = (TreeNode) tree.getModel().getRoot();  
        expandAll(tree, new TreePath(root), true);  
    }  
  
    /**      
    * 完全展开或关闭一个树,用于递规执行      
     * @param tree JTree      
    * @param parent 父节点      
     * @param expand 为true则表示展开树,否则为关闭整棵树      
     */  
    private static 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);  
            }  
        }   
  
        if (expand) {  
            tree.expandPath(parent);  
        } else {  
            tree.collapsePath(parent);  
        }  
    }  
    public static void main(String[] args) {
    	JTreeTest dJTreeTest = new JTreeTest();
    }
}  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值