我的目的是使用ListCellRenderer来突出显示包含已访问(或单击(链接的红色单元格,并突出显示未访问链接的绿色单元格,这部分有效,但不完全有效。渲染器似乎在将单元格标记为红色方面起作用。但是,如果我添加更多行,则它们之后都会变成红色。此外,如果我标记两个不相邻的单元格,那么它也将它们全部标记为红色。
我有一个类 Feed,我最初有一个布尔变量,但我修改了代码,以便m_isRead变量在列表中模型这里是构造函数:
public Feed (URL url, String urlName) {
this.m_urlName = urlName;
this.m_observers = new ArrayList<Observer>();
this.m_isRead = isRead;
}
现在,此实例变量在包含渲染器的 listModel 类中设置为 false。
m_isRead = false.
当使用我现在已调整的ListCellRenderer时,它不需要此方法:
m_feeds.get(index).getM_urlName();
我按如下方式进行:
class MyCellRenderer extends JLabel implements ListCellRenderer {
public MyCellRenderer() {
setOpaque(true);
}
public Component getListCellRendererComponent(JList list,
Object value,
int index,
boolean isSelected,
boolean cellHasFocus) {
setText(value.toString());
Color background = Color.GREEN;
Color foreground = Color.BLACK;
//find out if the specific has been read or not
if (m_feeds.get(index).isM_isRead() == true) {
background = Color.RED;
foreground = Color.WHITE;
} else {
background = Color.GREEN;
foreground = Color.BLACK;
};
setBackground(background);
setForeground(foreground);
return this;
}
}
然后我有另一个内部类,其中包含一个用于获取所选项目的方法,此时我将m_isRead设置为 true(读取(,这现在独立于 Feed 类,并且与之相关的代码已被注释掉:
public class ChangeSelectedIndex implements ListSelectionListener {
@Override
public void valueChanged(ListSelectionEvent e) {
for (int i = 0; i < m_listModel.size(); i++) {
if (m_listModel.getElementAt(i) != null) {
m_urlName = m_list.getSelectedValue();
initiateParsing();
m_updateFeedButton.setEnabled(true);
// TODO fix behavior for cell renderer
//this sets the value of the feed being clicked to true
// m_feeds.get(i).setM_isRead(true);
m_isRead = true;
}
}// end for
}
}
现在结果是一样的,如果我添加行,它们是绿色的,这是正确的,如果我单击每一行,只要我单击了相邻的行到我单击的第一行,但是如果我,例如,有四行,我单击第一行和最后一行, 所有行,包括介于两者之间的行(我没有单击(都变为红色。同样,如果我添加新行,它们会显示为红色。也就是说,如果我单击其中一行,那么我之后添加的行将是红色的。
有人可以帮忙吗?
提前谢谢你,
干杯
经过一段时间的思考,我得出结论,我原来的单元格渲染器没有错,它与列表模型本身有关。 JList 根本不支持多个 NON 连续选择,而无需立即单击 Ctrl 按钮。这就是触发我进一步搜索如何模拟 Ctrl 单击的原因;我在答案 8(工作代码(上找到的:
单个和非连续的 JTable 细胞选择
有趣的是将鼠标事件添加到列表中。 此鼠标事件模拟 Ctrl down 事件,JList 和 JTable 使用的 ListSelectionModel 设置为MULTPLE_SELECTION_INTERVAL它的行为符合预期。也就是说,用户现在能够单击任何提要,即使它不是连续的,并且它将为所需的提要着色,而不会为介于两者之间的任何未点击提要着色。
至于渲染器,使用isSelected参数就足够了,该参数通过其方法getListCellRenderer((提供。但是,就我而言,我所做的与添加具有相同的效果,即我使用数组来添加提要的所有状态,即已读或未读。 以这种方式进行,我想到如果我关闭程序并保存提要列表,包括将其 isRead 参数设置为 true 或 false,那么稍后在检索提要列表时,相同的提要状态将从例如文件中恢复,或者至少这是我的想法。