我有一个DefaultMutableTreeNode("birds"),它有n个孩子。现在,我想将这个节点添加到两个不同的父级DefaultMutableTreeNode("animals")和DefaultMutableTreeNodes("animals2").中
但是,当DefaultMutableTreeNode的add或insert方法首先从其父级移除子元素时。只在父节点中添加DefaultMutableTreeNode("birds")。两者以较迟被召唤者为准。
有办法绕过这件事吗?
DefaultMutableTreeNode birds = new DefaultMutableTreeNode("birds");
DefaultMutableTreeNode animals = new DefaultMutableTreeNode("animals");
DefaultMutableTreeNode animals2 = new DefaultMutableTreeNode("animals2");
animals.add(birds);
animals2.add(birds);发布于 2017-06-23 15:22:00
我最终得到了下面的解决方案
JTree.DynamicUtilTreeNode.createChildren(DefaultMutableTreeNode parent, Object children) JTree myTree = new JTree(parent)
这将一个根节点作为输入,子对象可以是数组、向量或哈希表。我最初使用hashtable来存储树的所有子节点(鸟),然后将它们添加到两个不同的根节点(动名词& animals2)中。
发布于 2017-06-21 15:11:37
如果我正确理解您的问题,最好的方法是创建一个提供“鸟类层次结构”的方法:
private DefaultMutableTreeNode createBirdsNode() {
DefaultMutableTreeNode birds = new DefaultMutableTreeNode("birds");
// add another nodes to birds node.
return birds;
}稍后,您可以使用此方法添加完整的层次结构。
animals.add(createBirdsNode());
animals2.add(createBirdsNode());https://stackoverflow.com/questions/44675629
复制相似问题