我知道以前已经以类似的方式问过这个问题,也许是图标。
我正在尝试的是更改树节点文本的颜色。
实际上,我有一个jTree,我将要设置三种不同的颜色,默认一种,红色和橙色。
目的是,如果我将该树与另一棵树进行比较,请突出显示两棵树之间的差异(默认表示无差异,橙色表示仅值差异,红色表示节点完全不同)
我有两个函数,一个遍历“原始”树,从比较的树中寻找一个节点,如果未找到{node},则返回false:
private Boolean findNodeInRefTree(DefaultTreeModel model, Object root, DefaultMutableTreeNode node){
Boolean bRet = false;
for (int i = 0; ((i < model.getChildCount(root))&&(!bRet)); i++){
DefaultMutableTreeNode child = (DefaultMutableTreeNode) model.getChild(root, i);
bRet = node.getUserObject().equals(child.getUserObject());
if (!bRet)
bRet = findNodeInRefTree(model, child, node);
}//for:i
return bRet;
}
另一个遍历“比较”树并为每个节点调用上面的函数。
private void compareTrees(TreeModel model, Object root){
for (int i = 0; i < model.getChildCount(root); i++){
DefaultMutableTreeNode child = (DefaultMutableTreeNode) model.getChild(root, i);
//find if node exists in original
DefaultTreeModel modelRef = (DefaultTreeModel) _ref.getModel();
if (!findNodeInRefTree(modelRef, modelRef.getRoot(), child)){
DefaultTreeCellRenderer render = (DefaultTreeCellRenderer) _temp.getCellRenderer();
render.setForeground(Color.RED);
_temp.setCellRenderer(render);
}//fi
_new.insertNodeInto((DefaultMutableTreeNode) child, (DefaultMutableTreeNode) root, i);
compareTrees(model, child);
}//for:i
}
然后,当它结束时,我只是将新树{_new}的模型设置为新树{_temp},并将树添加到其面板中。但是树没有任何不同的颜色。显然,我正在测试不同的树。有什么建议吗?
最佳答案
如果我正确理解您的代码,则在创建时进行比较,并在方法compareTrees
中为每个树节点设置渲染器(即多次)。
不幸的是,这不是摆动处理tree renderers的方式。在渲染树组件期间,应要求准备渲染器。因此,事先设置多个渲染器将无济于事。
一种可能的方法是进行比较并将结果(即颜色)保存在树模型中。然后,您可以编写一个基本的树渲染器,以读取当前节点的该值并相应地设置渲染颜色。