滚动后JTable数据不会显示?

时间:2013-07-18 08:07:58

标签: java swing jtable tablemodel

我在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();

        }

TestcaseTableModel

    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();
    }
}

感谢任何想法。

2 个答案:

答案 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)解决了问题感谢您的建议,我们乐于学习。