loadDefaultTableModel の rowData の最後の Vector インスタンスのみが実際の JTable に表示されます。何故ですか?
他のデータを含む他のベクトルはインスタンス化されていますが、モデルに追加されていないようです。少なくともそれらは表示されていません。
モデルに目的のデータが含まれていることを確認するにはどうすればよいですか? 必要なデータはロガーによって出力され、すでにベクトル形式になっています。矛盾がわかりません。
package net.bounceme.dur.nntp.swing;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Vector;
import java.util.logging.Logger;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;
import net.bounceme.dur.nntp.gnu.PageMetaData;
import net.bounceme.dur.nntp.gnu.Page;
import net.bounceme.dur.nntp.gnu.Usenet;
public class ArticlesTable extends JScrollPane {
private static final Logger LOG = Logger.getLogger(ArticlesTable.class.getName());
private static final long serialVersionUID = 1L;
private JTable jTable = new JTable();
private DefaultTableModel defaultTableModel = new DefaultTableModel();
private Page page;
private Usenet usenetConnection = Usenet.INSTANCE;
public ArticlesTable() throws Exception {
page = new Page();//eh, throws Exception -- fix later
LOG.fine(page.toString()); //empty Page
initComponents();
}
@SuppressWarnings("unchecked")
private void initComponents() {
defaultTableModel = new DefaultTableModel(new Object[][]{
{"some", "text"}, {"any", "text"}, {"even", "more"},
{"text", "strings"}, {"and", "other"}, {"text", "values"}},
new Object[]{"Column 1", "Column 2"});
jTable.setModel(defaultTableModel);
jTable.setSelectionMode(javax.swing.ListSelectionModel.SINGLE_SELECTION);
jTable.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseReleased(java.awt.event.MouseEvent evt) {
itemSelected();
}
});
jTable.addKeyListener(new java.awt.event.KeyAdapter() {
public void keyReleased(java.awt.event.KeyEvent evt) {
itemSelected();
}
});
setSize(2000, 2000); //not sure these lines are quite right, but ok for now
setViewportView(jTable);
jTable.setVisible(true);
setVisible(true);
}
private void itemSelected() {
int row = jTable.getSelectedRow();
int column = 0;
Object selectedObject = jTable.getValueAt(row, column);
int i = (int) selectedObject;
Map<Integer, Message> messages = page.getMessages();
Message message = messages.get(i);
firePropertyChange("message", null, message);
}
public final void nextPage() throws Exception {
LOG.fine("trying to get next page..." + page);
PageMetaData pageMetaData = page.getPageMetaData();
pageMetaData.next(); //only changes meta data
page = usenetConnection.getPage(pageMetaData); //fetches actual data
LOG.fine("was the page advanced?" + page); //yes, logs show this
loadDefaultTableModel();
LOG.fine(page.toString());
}
@SuppressWarnings("unchecked")
private void loadDefaultTableModel() throws MessagingException {
LOG.fine("trying to load...");
defaultTableModel = new DefaultTableModel();
defaultTableModel.addColumn("index");
defaultTableModel.addColumn("message subject");
Vector rowData = new Vector(); //vector?! nothing better?
Message message = null;
Map<Integer, Message> messages = page.getMessages(); //sort this
int key = 0;
LOG.info("trying to traverse..." + messages.size()); //page meta data determines the size
for (Entry<Integer, Message> entry : messages.entrySet()) {
rowData.clear();
key = entry.getKey();
message = messages.get(key);
rowData.add(key);
rowData.add(message.getSubject());
LOG.info("vector\t" + key + "\t" + message.getSubject());
//the vector logs the data which **should** get added
//to the table model
defaultTableModel.addRow(rowData); //adds same row over and over
}
jTable.setModel(defaultTableModel);
}
private Message getMessage(int i) {
LOG.fine("trying to get\t\t" + i);
Map<Integer, Message> messages = page.getMessages();
Message m = messages.get(i);
return m;
}
}
画像:
出力の一部:
INFO: trying to traverse...5
Apr 15, 2013 2:05:13 AM net.bounceme.dur.nntp.swing.ArticlesTable loadDefaultTableModel
INFO: vector 25 Re: Netbeans question?
Apr 15, 2013 2:05:13 AM net.bounceme.dur.nntp.swing.ArticlesTable loadDefaultTableModel
INFO: vector 27 Re: Helpppp plzzz
Apr 15, 2013 2:05:13 AM net.bounceme.dur.nntp.swing.ArticlesTable loadDefaultTableModel
INFO: vector 26 Re: writing Unix files on Windows
Apr 15, 2013 2:05:13 AM net.bounceme.dur.nntp.swing.ArticlesTable loadDefaultTableModel
INFO: vector 29 JTextPane.modelToView() exception
Apr 15, 2013 2:05:13 AM net.bounceme.dur.nntp.swing.ArticlesTable loadDefaultTableModel
INFO: vector 28 Java 6 update 39 to 41 balloon
ご覧のとおり、各ベクター インスタンスには正しいデータが含まれています。ただし、最初のインスタンスのみが GUI 出力に表示されるようです。なんで?
モデルに正しく追加されていませんか? モデルがテーブルを正しく更新していませんか?
GUI に表示されるモデルのデータが、ログに記録された出力と一致しないのはなぜですか?