jtree中的文件夹排序

时间:2013-02-20 11:03:35

标签: java swing sorting jtree comparator

有没有办法对已经创建的只有root的树(DefaultMutableTreeNode)进行排序?它具有随机顺序的文件夹和文件(使用ierarchy)。是否可以按字母顺序在文件顶部显示文件夹?

1 个答案:

答案 0 :(得分:1)

您可以使用以下递归方法实现

public static DefaultMutableTreeNode sortTree(DefaultMutableTreeNode root) {
    {
        for (int i = 0; i < root.getChildCount() - 1; i++) {
            DefaultMutableTreeNode node = (DefaultMutableTreeNode) root
                    .getChildAt(i);
            String nt = node.getUserObject().toString();

            for (int j = i + 1; j <= root.getChildCount() - 1; j++) {
                DefaultMutableTreeNode prevNode = (DefaultMutableTreeNode) root
                        .getChildAt(j);
                String np = prevNode.getUserObject().toString();

                System.out.println(nt + " " + np);
                if (nt.compareToIgnoreCase(np) > 0) {

                    root.insert(node, j);
                    break;
                }
            }
            if (node.getChildCount() > 0) {
                node = sortTree(node);
            }
        }

        return root;
    }
}