До сих пор у меня было такое определение JTable:
JTable table = new JTable(model) {
@Override
public Component prepareRenderer(TableCellRenderer renderer, int row, int column) {
Component c = super.prepareRenderer(renderer, row, column);
TradeTableModel model = (TradeTableModel) getModel();
if ((Boolean) model.getValueAt(row, model.findColumn("Select"))) {
Side s = (Side) model.getValueAt(row, model.findColumn("Side"));
if (s == Side.BUY)
c.setBackground(Color.BLUE);
else
c.setBackground(Color.red);
}
else {
c.setBackground(Color.white);
}
return c;
}
};
Это было сделано для того, чтобы строки изменяли цвет в зависимости от выбора логического значения столбца. В моем AbstractTableModel
я указал метод установки значения следующим образом:
public void setValueAt(Object aValue, int rowIndex, int columnIndex) {
assert columnIndex == 5;
try{
Selectable t = trades.get(rowIndex);
t.setSelected((Boolean)aValue);
fireTableDataChanged();
//fireTableCellUpdated(rowIndex, columnIndex);
}
catch(Exception e){
throw new IllegalArgumentException("Object to set was not subtype of boolean");
}
}
Если я использую fireTableDataChanged()
, цвет обновляется, когда я устанавливаю флажок в графическом интерфейсе. Однако я действительно хочу отправить fireTableCellUpdated(rowIndex, columnIndex)
, так как другим обработчикам нужно знать местоположение ячейки. Однако в этом сценарии строка изменяется только в том случае, если я нажимаю на другую строку в таблице, как если бы она была отложена и ждала какого-то другого события.
Любые идеи, почему это так?