当我更改数据时,我拼命试图说服我的JTable
刷新。数据存储在我正在使用的全局单例TreeSet
中。每当TreeSet
s数据被更改时,都会触发一个事件来刷新TableModel
。出于测试目的,我将其替换为简单的Timer
触发事件。
每次触发事件时,都会删除TreeSet
中的元素以模拟数据中的更改。事件触发并且TableClass
接收它并按预期处理它,但是当提到刷新时没有任何事情发生。我每次发生事件时都尝试创建一个新的TableModel
并将其设置为全局表。对单身TreeSet
进行了更改,但JTable
没有任何反应。
public class TreeTableObj implements ActionListener{
public JTable table ;
public TreeTableObj(){
MyTableModel myModel = new MyTableModel(getValuesOfTreeSet(), getTreeSetRows());
table = new JTable( myModel){ //some rendering };
table.setAutoCreateRowSorter(true);
}
class MyTableModel extends AbstractTableModel {
private String[] columnNames;
private Object[][] data ;
public MyTableModel(Object[][] data, String[] columnNames){
this.data = data;
this.columnNames = columnNames;
System.out.println("Model created");
}
public int getColumnCount() {
return columnNames.length;
}
public int getRowCount() {
return data.length;
}
public String getColumnName(int col) {
return columnNames[col];
}
public Object getValueAt(int row, int col) {
return data[row][col];
}
public void setData(Object[][] data){
this.data = data;
fireTableDataChanged();
}
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
public boolean isCellEditable(int row, int col) {
if (col < 2) {
return false;
} else {
return true;
}
}
public void setValueAt(Object value, int row, int col) {
if (true) {
System.out.println("Setting value at " + row + "," + col
+ " to " + value
+ " (an instance of "
+ value.getClass() + ")");
}
data[row][col] = value;
fireTableCellUpdated(row, col);
if (true) {
System.out.println("New value of data:");
printDebugData();
}
}
private void printDebugData() {
int numRows = getRowCount();
int numCols = getColumnCount();
for (int i=0; i < numRows; i++) {
System.out.print(" row " + i + ":");
for (int j=0; j < numCols; j++) {
System.out.print(" " + data[i][j]);
}
System.out.println();
}
System.out.println("--------------------------");
}
}
public void refreshTableModel(){
FlightsTreeSet.getInstance().remove(FlightsTreeSet.getInstance().first());
table.setModel(new MyTableModel(getValuesOfTreeSet(), getTreeSetRows()));
}
public void actionPerformed(ActionEvent arg0) {
refreshTableModel();
}
}
任何帮助将不胜感激!
[EDIT1]
我越来越接近问题核心: 我发现在JFrame中显示的表包含另一个引用作为我更改的引用。我将所有更改都显示出来并应用于模型。
答案 0 :(得分:2)
代码中缺少什么?您的表模型不应该编译,因为它缺少JTable用于访问数据的所有方法(getColumnCount()
,getValueAt()
等。)
此外,您不必在每次更改时都创建新模型 - 只需拥有模型fireTableStructureChanged()
。
答案 1 :(得分:1)
我发现了问题。在这里留下答案是别人找到的......
在意识到显示的JTable
和我正在编辑的那个持有不同的引用(参见[EDIT1])后,我发现我正在创建JTable
的两个不同的对象。一个要显示,另一个要main()
成为ActionListener
。听众收到了事件并进行了更改,但另一个从未注意到发生了任何事情。