1

所以我有一个大型卡片布局,其中一个面板作为 JTable:

tbm = new DefaultTableModel();  
tbm.addColumn("Account Number"); 
tbm.addColumn("PIN"); 
tbm.addColumn("Access Level"); 
tbm.addColumn("Balance");
table = new JTable(tbm);
JScrollPane scrollPane = new JScrollPane(table);

在actionPerformed下,我试图将一些数据加载到表中,如下所示:

else if(event.getSource() == listallButton) {
      String query = "SELECT * FROM ATM";
      String delimiter = ",";
      String input = "go";
      int count=0;
      al = new ArrayList<String>();

          try {
              communicationObject = new DataObject();
              communicationObject.setMessage(query);
              Socket socketToServer = new Socket("sunlab32.njit.edu",31414);
              ObjectOutputStream myOutputStream = new ObjectOutputStream(socketToServer.getOutputStream());
              ObjectInputStream myInputStream = new ObjectInputStream(socketToServer.getInputStream());
              myOutputStream.writeObject(communicationObject);
              communicationObject = (DataObject)myInputStream.readObject();
              input = communicationObject.getMessage();
              if (input != "stop") {
                  al.add(input);
                  data[count] = input;
                  count++; }

              for (int i=0;i<data.length;i++) {
                  row = data[i];
                  temp = row.split(delimiter);
                  tbm.addRow(new String[] {temp[0],temp[1],temp[2],temp[3]}); } 
              tbm.fireTableDataChanged();
              table.repaint();

现在我的问题是在加载所有行后表格没有重新绘制......有什么建议吗?

4

2 回答 2

4

tbm.addModel应该是触发表更改事件,所以tbm.fireTableDataChanged没有必要。

您可以尝试这样做以在添加所有行后强制它自行绘制。

table.setModel(tbm);

无关:

Swing 是单线程事件模型,这意味着您正在执行的任务将阻止 UI 更新。

我建议您将数据加载移动到 SwingWorker,一旦完成更改,将数据推送到 UI 上。看看这个教程

于 2012-05-01T03:42:44.270 回答
1

没有必要打电话tbm.fireTableDataChanged();。模型本身将通知表以响应addRow()。如果表格和模型连接正确,表格将自行刷新。

您可能会发现此示例很有帮助,它演示了DefaultTableModel.

由于此代码不可见,请确保表格和滚动窗格设置正确。此外,请确保您的查询实际返回数据。

于 2012-05-01T03:20:00.430 回答