java如何将我的树结构转换成Jtree?
首先,我应该说我正在使用netbeans,而且我对整个javagui游戏还不熟悉
所以,我的问题是,我创建了自己的树结构,专门用于我的项目,现在我想使用我的结构来构建JTree
我正在阅读关于Jtree的主题,据我所知,我需要在我的结构中实现TreeModel接口。我还了解到的另一种方法是使用DefaultMutableTreeNode,但我找不到任何我清楚的使用它的示例
现在,我已经构建了我的整个树结构,并填充了数据,我试图避免重建它。如何将我的树实现为Jtree
package models;
import java.util.ArrayList;
import java.util.List;
public class IngredientTree {
private Node root;
public IngredientTree(){
root = new Node();
}
public IngredientTree(Node rootData) {
root = rootData;
}
public void setRoot(Node n){
root = n;
}
public Node getRoot(){
return root;
}
public void addToTree(Ingredient i){
if(root.getData().getName()=="") // Then it must be the root
root.setData(i);
else
addToTree(root,i);
}
private void addToTree(Node n, Ingredient i){
if(isFirstAdd(n)) //Has no parent and no children
n.addChild(new Node(i,n));
else if(n.hasChildren()){ //Has parent and children
if(!inChildren(n,i)){
if(inNode(n,i))
n.addChild(new Node(i,n));
}
else{
for(Node child : n.getChildren()){
addToTree(child,i);
}
}
}
else{ //Has parent but no children
n.addChild(new Node(i,n));
}
}
private boolean isFirstAdd(Node n){
return(!n.hasParent() && !n.hasChildren());
}
private boolean inChildren(Node n,Ingredient i){
for(Node child : n.getChildren()){
if(inNode(child,i))
return true;
}
return false;
}
private boolean inNode(Node n,Ingredient i){
return(i.getStartIndex() > n.getData().getStartIndex() &&
i.getEndIndex() < n.getData().getEndIndex());
}
public int countIngredients(){
return countIngredients(this.getRoot());
}
private int countIngredients(Node r){
int count = 0;
if(!r.hasChildren()){
return 1;
}else{
for(Node child: r.getChildren()){
count += countIngredients(child);
}
}
return count;
}
}
# 1 楼答案
对^引用的{a1}就是一个例子。如How to Use Trees: Creating a Data Model中所述,“您只需要实现树模型,以便它使用现有数据结构中的信息。”
# 2 楼答案
# 3 楼答案