TableCellRenderer可以正常工作,表可以很好地排序,但不会重新绘制

时间:2018-08-04 10:22:20

标签: java swing background jtable

这是我的JTable鼠标侦听器,我将其放在表中是因为它希望直接对其进行排序。

myTable= new JTable();
myTable.addMouseListener(new MouseAdapter() {
    @Override
    public void mouseClicked(MouseEvent arg0) {
        if( myTable.getRowCount()!= 0) {
            TableRowSorter<TableModel> sorter = new TableRowSorter(myTable.getModel());
            myTable.setRowSorter(sorter);
            List<RowSorter.SortKey> date= new ArrayList<>();

            int columnIndexToSort = 10;
            datum.add(new RowSorter.SortKey(columnIndexToSort, SortOrder.DESCENDING));

            sorter.setSortKeys(date);
            sorter.sort();
        }
        myTable.repaint();
        myTable.revalidate();
    }
});

这是BTW的单元格渲染器,效果很好,但排序后不会重新绘制:

public class MyTableRenderer extends DefaultTableCellRenderer{
private static final long serialVersionUID = 1L;

public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus,int row,int col) {
    Component c = super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, col);

        Object resault = table.getModel().getValueAt(row, 9);
        int value= Integer.parseInt(resault.toString()); 
        Color color = null;

        if (value>= 5000) {
            c.setBackground(new Color(144, 238, 144));
        }else if (value< 5000 && value>=500) {
            color = Color.ORANGE;
            c.setBackground(color);
        }else if (value>= 0 && value<500) {
            c.setBackground( new Color(255, 76, 76));
        }
            c.setFont(c.getFont().deriveFont(Font.BOLD));
        return c;
    }
}

这些是我记得要说的一些有关此特定问题的内容,如果存在无法理解的任何内容,请回答。

1 个答案:

答案 0 :(得分:1)

Object resault = table.getModel().getValueAt(row, 9);

渲染器在表视图中显示数据。对数据进行排序时,TableModel中的数据不会更改,只会更改视图中数据的顺序。

因此您应该使用:

Object result = table.getValueAt(row, 9);

排序后在当前视图中获取数据。