0

これを使用してa のすべての行を削除していますJTable:

myTableModel.getDataVector().removeAllElements();
myTableModel.setRowCount(0);

しかし、削除した後、その足跡が残ります! このスクリーンショットを確認してください:
削除後の JTable

これは、すべての行を削除した場合にのみ発生し、行が 1 つでもあると問題が発生します。
なぜこれが起こるのですか?どうすれば修正できますか?
ありがとう

4

1 に答える 1

1

を使用するDefaultTableModel場合、唯一のオプションは、モデルによって提供される機能を使用することです。removeRow

removeRowJTableは、自分自身を更新する必要があることを に伝えるために必要な適切なイベントを発生させます。テーブルは、塗装プロセスを改善するために最適化されています

ここに画像の説明を入力ここに画像の説明を入力

import java.awt.BorderLayout;
import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import javax.swing.AbstractAction;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableModel;

public class TestTable {

    public static void main(String[] args) {
        new TestTable();
    }

    public TestTable() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                }

                DefaultTableModel model = new DefaultTableModel();
                JTable table = new JTable(model);
                for (int index = 0; index < 10; index++) {
                    model.addColumn(index);
                }
                for (int row = 0; row < 1000; row++) {
                    String[] values = new String[10];
                    for (int col = 0; col < 10; col++) {
                        values[col] = row + "x" + col;
                    }
                    model.addRow(values);
                }

                JFrame frame = new JFrame("Test");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.setLayout(new BorderLayout());
                frame.add(new JScrollPane(table));
                frame.add(new JButton(new DeleteRowsFromDefaultModel(model)), BorderLayout.SOUTH);
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }

        });
    }

    public class DeleteRowsFromDefaultModel extends AbstractAction {

        private final DefaultTableModel model;

        public DeleteRowsFromDefaultModel(DefaultTableModel model) {
            this.model = model;
            putValue(NAME, "Delete All");
        }

        @Override
        public void actionPerformed(ActionEvent e) {
            model.setRowCount(0);
        }

    }

}

パフォーマンスが本当に心配な場合は、独自のモデルを作成しclear、適切なイベントを発生させる独自のメソッドを作成する必要があります。

import java.awt.BorderLayout;
import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.util.ArrayList;
import java.util.List;
import javax.swing.AbstractAction;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.table.AbstractTableModel;
import javax.swing.table.DefaultTableModel;

public class TestTable1 {

    public static void main(String[] args) {
        new TestTable1();
    }

    public TestTable1() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                }

                MyTabelModel model = new MyTabelModel();
                JTable table = new JTable(model);

                JFrame frame = new JFrame("Test");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.setLayout(new BorderLayout());
                frame.add(new JScrollPane(table));
                frame.add(new JButton(new DeleteRowsFromMyModel(model)), BorderLayout.SOUTH);
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    public class DeleteRowsFromMyModel extends AbstractAction {

        private final MyTabelModel model;

        public DeleteRowsFromMyModel(MyTabelModel model) {
            this.model = model;
            putValue(NAME, "Delete All");
        }

        @Override
        public void actionPerformed(ActionEvent e) {
            model.clear();
        }
    }

    public class MyTabelModel extends AbstractTableModel {

        private List<String[]> rows;

        public MyTabelModel() {
            rows = new ArrayList<>(1000);
            for (int row = 0; row < 1000; row++) {
                String[] values = new String[10];
                for (int col = 0; col < 10; col++) {
                    values[col] = row + "x" + col;
                }
                rows.add(values);
            }
        }

        @Override
        public int getRowCount() {
            return rows.size();
        }

        @Override
        public int getColumnCount() {
            return 10;
        }

        @Override
        public String getColumnName(int column) {
            return String.valueOf(column);
        }

        @Override
        public Object getValueAt(int rowIndex, int columnIndex) {
            String[] row = rows.get(rowIndex);
            return row[columnIndex];
        }

        public void clear() {
            int old = getRowCount();
            if (old > 0) {
                rows.clear();
                fireTableRowsDeleted(0, old - 1);
            }
        }
    }
}
于 2013-04-24T23:50:10.183 に答える