到目前为止,我对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()
,则在单击gui上的复选框时会更新颜色。但是,我真的想发送fireTableCellUpdated(rowIndex, columnIndex)
,因为其他处理程序需要知道单元的位置。但是,在这种情况下,仅当我单击表中的另一行时,该行才会更改,就好像它已延迟并等待其他事件发生一样。知道为什么会这样吗?
最佳答案
您的(看不见的)TableModel
应该根据需要fireTableXxxXxxx()
以便通知所有侦听器。 DefaultTableModel
自动执行此操作; AbstractTableModel
应该在setValueAt()
中这样做。表本身就是这样的一种监听器。如果“其他处理程序需要知道单元的位置”,则可以通过TableModelEvent
为addTableModelListener()
实例register。他们还可以根据需要收听User Selections。
关于java - JTable中关于fireTableDataChanged的怪异行为,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11781715/