ListCellRenderer 将所有行设置为相同的颜色



我的目的是使用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,那么稍后在检索提要列表时,相同的提要状态将从例如文件中恢复,或者至少这是我的想法。

相关内容

  • 没有找到相关文章

最新更新