我在应用程序中使用了一个树表模型,该模型扩展了AbstractTreeTableModel
以创建JXTreeTable
。下面是我的模型。
import org.jdesktop.swingx.treetable.AbstractTreeTableModel;
import org.jdesktop.swingx.treetable.DefaultTreeTableModel;
import org.jdesktop.swingx.treetable.TreeTableModel;
import javax.swing.tree.TreeModel;
public class MyDataModel extends AbstractTreeTableModel{
static protected String[] columnNames = { "Field", "Value" };
static protected Class<?>[] columnTypes = { Object.class, Object.class};
public MyDataModel(MyDataNode rootNode) {
super(rootNode);
root = rootNode;
}
@Override
public Object getChild(Object parent, int index) {
return ((MyDataNode) parent).getChildren().get(index);
}
@Override
public int getChildCount(Object parent) {
return ((MyDataNode) parent).getChildren().size();
}
@Override
public int getIndexOfChild(Object parent, Object child) {
return 0;
}
@Override
public int getColumnCount() {
return columnNames.length;
}
@Override
public String getColumnName(int column) {
return columnNames[column];
}
@Override
public Class<?> getColumnClass(int column) {
return columnTypes[column];
}
@Override
public Object getValueAt(Object node, int column) {
MyDataNode mNode=(MyDataNode)node;
Object obj =mNode.getNodeDataObject();
if(column==0){
return mNode.getName();
}
else if (column==1){
if(obj instanceof Field){
Field field=(Field)mNode.getNodeDataObject();
if(field.getFieldDef().getListValue().size()>0){
return field.getFieldDef().getListValue();
}
else
return mNode.getDefaultValue();
}
else
return mNode.getDefaultValue();
}
return null;
}
@Override
public boolean isCellEditable(Object node, int column) {
//only allow Field values to be editable
if(((MyDataNode)node).getNodeDataObject() instanceof Field && column==1)
return true;
else
return false;
}
@Override
public boolean isLeaf(Object node) {
MyDataNode mNode=(MyDataNode)node;
Object obj=mNode.getNodeDataObject();
if(obj instanceof Field){
Field field=(Field)obj;
if(field.getFieldDef().getDataType().equalsIgnoreCase("MULTIPLE_MESSAGE")){
return false;
}
else
return true;
}
return false;
}
@Override
public void setValueAt(Object aValue, Object node, int column) {
MyDataNode mNode=(MyDataNode)node;
if (mNode.getNodeDataObject() instanceof Field && column == 1) {
Field field = (Field) mNode.getNodeDataObject();
field.setDefaultValue(aValue);
field.setSelectedValue(aValue);
}
}
}
这就是我在应用中使用JXTreeTable
的方式
MyDataModel treeTableModel = new MyDataModel(createDataStructure(message));
jTreeTable = new JXTreeTable(treeTableModel);
private static MyDataNode createDataStructure(Message message) {
//setting fields as children of the root
nodeList = new ArrayList<>();
for (int index=0;index<message.getListFields().size() ; index++) {
if(message.getListFields().get(index).getFieldDef()
.getDataType().equalsIgnoreCase("MULTIPLE_MESSAGE")){
nodeList.add(new MyDataNode(message.getListFields()
.get(index).getFieldDef().getfName(), "", childMessagesRoot,
message.getListFields().get(index)));
}
else{
nodeList.add(new MyDataNode(message.getListFields()
.get(index).getFieldDef().getfName(), (String)(message.getListFields().
get(index).getDefaultValue()),
null,message.getListFields().get(index)));
}
}
//setting the Message to the root of the tree
root = new MyDataNode(message.getMsgName(), "", nodeList,message);
return root;
}
当我需要向JXTreeTable
添加新节点时,我尝试获取其模型并使用insertNodeInto()
函数调用,但该模型不支持insertNodeInto()
函数。
有人请告诉我代码哪里出错了。这是我第一次使用树表,所以可能缺少一些东西。
insertNodeInto
是DefaultTreeTableModel的一个方法,但不是AbstractTreeTableModel中的一个。
让MyDataModel
扩展DefaultTreeTableModel
而不是AbstractTreeTableModel
以能够使用insertNodeInto
。
当通过JXTreeTable#getTreeTableModel
访问TreeTableModel
时,记得在调用insertNodeInto
之前将返回的类型为TreeTableModel
的对象强制转换为DefaultTreeTableModel
。
我发现哪里出了问题。我用DefaultTreeTableModel扩展了MyDataModel类,并使我的节点类(我使用的是自定义节点类)扩展了DefaultMutableTreeTableNode。这提供了使用insertNodeInto方法获取树表当前选定节点的解决方案。