3

当用户双击时,我试图使 JTable 的所有单元格都不可编辑。我读了很多论坛帖子,普遍的共识是创建一个新的表模型类,扩展 DefaultTableModel 然后覆盖方法 isCellEditable(int row, int column)。我做了所有这些,现在当我运行我的程序(小程序)时,单元格中没有显示任何内容。注意这个学期我有一位教授认为小程序并没有过时......

表模型的代码:

public class MyTableModel extends DefaultTableModel
{
    public boolean isCellEditable(int row, int column)      //override isCellEditable
    //PRE:  row > 0, column > 0
    //POST: FCTVAL == false always
    {
        return false;
    }
}

    Code in my class:  **NOTE** this class extends JPanel 

    private JScrollPane storesPane;                
    private JTable storesTable; 

    Code in the Constructor:             

    storesTable = new JTable(tableData, COL_NAMES);    //tableData and COL_NAMES are passed in
    storesTable.setModel(new MyTableModel());

    storesPane = new JScrollPane(storesTable);
    storesTable.setFillsViewportHeight(true);
    add(storesPane, BorderLayout.CENTER);     

希望你们中的一些 Java 大师能找到我的错误 :)

4

4 回答 4

6

这一行创建了一个新的 JTable,并在后台隐式创建了一个 DefaultTableModel,它包含 JTable 所需的所有正确数据:

storesTable = new JTable(tableData, COL_NAMES);

这一行有效地删除了上面隐式创建的表模型,该模型包含所有表的数据并用不包含任何数据的表模型替换它:

storesTable.setModel(new MyTableModel());

您需要为您的 MyTableModel 类提供一个构造函数,并在该构造函数中调用超级构造函数并将您当前传递给其构造函数中的表的数据传入。

例如,

public class MyTableModel extends DefaultTableModel {

   public MyTableModel(Object[][] tableData, Object[] colNames) {
      super(tableData, colNames);
   }

   public boolean isCellEditable(int row, int column) {
      return false;
   }
}

然后你可以像这样使用它:

MyTableModel model = new MyTableModel(tableData, COL_NAMES);
storesTable = new JTable(model);
于 2011-12-04T02:34:53.733 回答
3

今天早些时候,我遇到了同样的问题。这为我解决了。

    JTable table = new JTable( data, headers ){  
      public boolean isCellEditable(int row, int column){  
        return false;  
      }  
    };  

效果很好!

于 2014-01-06T02:02:25.100 回答
3

只需覆盖类的isCellEditable方法DefaultTableModel。快速执行此操作的方法:

JTable table = new JTable();
DefaultTableModel dtm = new DefaultTableModel(0, 0) {
    public boolean isCellEditable(int row, int column) {
        return false;
    }
};
table.setModel(dtm);
于 2015-06-02T18:51:37.837 回答
1

Hello Friend am also working on table please try my code

    import javax.swing.table.AbstractTableModel;

    public class Table extends AbstractTableModel {

    private boolean DEBUG = false;
    private String[] columnNames = {"                Date Time", "                Parameter",
    "   Barometric Pressure (hPa)", "           Temperature (°C)", "             Battery             Voltage    (V)"};

public static Object[][] data = {};


public TableControllerViewdataTabTableModel() {
}

@Override
public int getColumnCount() {
    return columnNames.length;
}

@Override
public int getRowCount() {
    return data.length;
}

@Override
public String getColumnName(int col) {
    return columnNames[col];
}

@Override
public Object getValueAt(int row, int col) {
    return data[row][col];
}

@Override
public Class getColumnClass(int c) {
    return getValueAt(0, c).getClass();
}

@Override
public boolean isCellEditable(int row, int col) {
    return false;

}

@Override
/**
 * The setValueAt.
 */
public void setValueAt(Object value, int row, int col) {
    data[row][col] = value;
    fireTableCellUpdated(row, col);

    if (DEBUG) {

        printDebugData();
    }
}

/**
 * The printDebugData.
 */
private void printDebugData() {
    int numRows = getRowCount();
    int numCols = getColumnCount();

    for (int i = 0; i < numRows; i++) {

        for (int j = 0; j < numCols; j++) {
        }

    }

}
}
于 2014-01-06T04:10:10.170 回答