我知道以前曾以类似的方式提出过这个问题,也许是针对图标。我正在尝试更改树节点文本的颜色。事实上,我有一个 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},并将树添加到其面板。但是这棵树没有任何不同的颜色。显然,我正在用不同的树进行测试。有什么建议吗?