3

JTableデータを変更したときに更新するように必死に説得しようとしています。データは、TreeSet私が使用しているグローバル シングルトン に保存されます。s データが変更されるたびTreeSetに、イベントが発生して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();    
    }
}

どんな助けでも大歓迎です!

[編集1]

コアの問題に近づいています。JFrame に表示されるテーブルが、変更したものとして別の参照を保持していることがわかりました。すべての変更を表示して、モデルに適用します。

4

2 に答える 2

2

コードに何か不足していますか? getColumnCount()JTable がデータにアクセスするために使用するすべてのメソッド ( 、getValueAt()など)が欠落しているため、そのままのテーブル モデルはコンパイルされません。

また、変更のたびに新しいモデルを作成する必要はありません。モデルを持っているだけfireTableStructureChanged()です。

于 2012-05-09T12:43:27.417 に答える
1

問題が見つかりました。そして、他の人が見つけられるように答えをここに残します...表示されJTableているものと編集していたものが異なる参照を保持していることに気付いた後([EDIT1]を参照)、 の2つの異なるオブジェクトを作成していることがわかりましたJTable。1 つは表示され、もう 1 つはmain()になりますActionListener。リスナーはイベントを受け取り、変更を行いましたが、他のリスナーは何かが起こっていることに気づきませんでした。

于 2012-05-09T21:50:00.260 に答える