我在ScrollPane中有一个JTable包含来自扩展DefaultTableModel的数据。当我将数据加载到表中时,它显示了列。滚动条显示数据存在,但没有显示。我滚动数据后立即出现。我在模型上尝试了所有类型的fire()事件,在Jtable上尝试了.repaint(),. updateT等,但是无法使其正常工作。显然不会调用CellRenderer。我该如何解决这个问题?
public void setTestcaseModel(TestcaseTableModel testcase_model, List<String> names) {
this.testcaseTableModel = testcase_model;
testcaseTable.setModel(this.testcaseTableModel);
testcaseTable.setRowHeight(40);
TableColumn column = testcaseTable.getColumnModel().getColumn(0);
column.setCellRenderer(new TestcaseCellRenderer(names, this, tgc));
TestcaseCellEditor editor = new TestcaseCellEditor(testcaseTable,this);
column.setCellEditor(editor);
editor.addCellEditorListener(tgc);
this.testcaseTableModel.fireTableDataChanged();
}
package gui.table;
import java.util.List;
import java.util.Vector;
import javax.swing.table.DefaultTableModel;
import org.jdom2.Element;
@SuppressWarnings("serial")
public class TestcaseTableModel extends DefaultTableModel {
String[] columnNames = { "Testcase" };
Vector<String[]> row_data = new Vector<String[]>();
public TestcaseTableModel(Element testSuite) {
row_data.clear();
List<Element> testcase_list = testSuite.getChildren("TestCase");
String[] data;
for (int i = 0; i < testcase_list.size(); i++) {
data = new String[4];
data[0] = "";
data[1] = "failed";
data[2] = testcase_list.get(i).getAttributeValue("id");
data[3] = "play";
row_data.add(data);
}
}
@Override
public void setValueAt(Object value, int row, int col) {
// Output gui NULL exception
if (value == null)
return;
row_data.elementAt(row)[col] = value.toString();
fireTableCellUpdated(row, col);
}
@Override
public int getColumnCount() {
return columnNames.length;
}
@Override
public int getRowCount() {
return row_data == null ? 0 : row_data.size();
}
@Override
public String getValueAt(int row, int col) {
return row_data.elementAt(row)[col];
}
public String getColumnName(int column) {
return columnNames[column];
}
public void clear(){
row_data.clear();
fireTableDataChanged();
}
}
感谢任何想法。
答案 0 :(得分:3)
您正在扩展DefaultTableModel。 DefaultTableModel已经将列名和数据存储在自己的向量中。它的所有方法都在DefaultTableModel的向量中查找数据。
您的子类重新创建另一个矢量来存储数据。这不可行:基类方法不知道并关心这个新的向量。
您希望自己的数据结构存储数据和列名称,并且应该扩展AbstractTableModel
。或者您想使用DefaultTableModel
,并且您不能拥有自己的数据结构,因为DefaultTableModel
已经定义了自己的数据结构。除getColumnClass()
外,您不应覆盖DefaultTableModel
的任何方法。如果你这样做,或者你添加方法,那么这些方法应该始终委托给DefaultTableModel
的方法。
例如:
public class TestcaseTableModel extends DefaultTableModel {
// no vector here!!
public TestcaseTableModel(Element testSuite) {
// delegate to the parent constructor
super(createDataVector(testSuite), createColumNames());
}
private static Vector<Vector<Object>> createDataVector() {
List<Element> testcase_list = testSuite.getChildren("TestCase");
Vector<Vector<Object>> data;
for (int i = 0; i < testcase_list.size(); i++) {
Vector<Object> row = new Vector<Object>();
row.add("");
row.add("failed");
row.add(testcase_list.get(i).getAttributeValue("id"));
row.add("play");
data.add(row);
}
return data;
}
private static Vector<String> createColumnNames() {
Vector<String> result = new Vector<String>();
result.add("TestCase");
result.add("");
result.add("");
result.add("");
return result;
}
/**
* overridden to ignore null values
*/
@Override
public void setValueAt(Object value, int row, int col) {
if (value == null) {
return;
}
// delegate to the parent method
super.setValueAt(value, row, col);
}
}
答案 1 :(得分:0)
table.setVisible(true)解决了问题感谢您的建议,我们乐于学习。