[英]Completely expand all node of a Jtree (including children)
我在互联网上找到了有关此问题的一些详细信息,但该解决方案似乎不起作用。
我希望能够展开JTree
所有节点(包括叶节点)。 这是我到目前为止的代码。
tree = new JTree(treeModel);
tree.setShowsRootHandles(true);
tree.setEditable(true);
tree.addTreeSelectionListener(treeSelectionListener);
tree.addMouseListener(mouselistener);
tree.setCellRenderer(new FileCellRenderer());
for (int i = 0; i < tree.getRowCount(); i++) {
tree.expandRow(i);
}
然而,这不会扩展所有叶节点。 我得到的是 IMAGE A但我想要的是 IMAGE B :
使用递归调用,如以下示例所示:
private void expandAllNodes(JTree tree, int startingIndex, int rowCount){
for(int i=startingIndex;i<rowCount;++i){
tree.expandRow(i);
}
if(tree.getRowCount()!=rowCount){
expandAllNodes(rowCount, tree.getRowCount());
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.