在度过了一个下午的时间后,我终于找到了一个问我问题的帐户,希望有人可以帮助我。
我正在内部框架中创建一个JTable。我有自己的tableModel和cellRenderer(因为我希望用户只能编辑表格边框的单元格,而我希望不可编辑的单元格是灰色的)。它工作正常,不可编辑的单元格是灰色的,我们对此一无所知。其他情况下,我们可以在修改值并按Enter时使用它,但是什么也没有发生,该值恢复为默认值。我试图使用“ setValueAt()”方法修改代码中的单元格值,但我也不起作用。
我试图实现一些侦听器,但没有任何效果:/。你能帮我吗?我希望我足够清楚。这是我要提供帮助的代码:
MyCellRenderer.java(完美运行)
import java.awt.Color;
import java.awt.Component;
import javax.swing.JTable;
import javax.swing.table.DefaultTableCellRenderer;
public class MyCellRenderer extends DefaultTableCellRenderer {
@Override
public Component getTableCellRendererComponent(
JTable table, Object value, boolean isSelected,
boolean hasFocus, int row, int column){
if (table.isCellEditable(row, column)) {
setBackground(Color.white);
}
else {
setBackground(Color.darkGray);
}
return super.getTableCellRendererComponent(table, value, isSelected,
hasFocus, row, column);
}
}
MyTableModel.java(完美运行)
import javax.swing.table.DefaultTableModel;
public class MyTableModel extends DefaultTableModel{
public boolean[][] canEdit = new boolean[][]{};
public void setEditModel(int maxRow, int maxCol){
canEdit = new boolean[maxRow][maxCol];
for(int col=0;col< maxCol; col++){
for(int row=0;row< maxRow; row++){
if(col == 0 || row == 0 || col == maxCol-1){
canEdit[row][col] = true;
}
else{
canEdit[row][col] = false;
}
}
}
}
@Override
public boolean isCellEditable(int rowIndex, int columnIndex) {
return canEdit[rowIndex][columnIndex];
}
}
这是我主机的一部分。当我按下此按钮时,它将在内部框架中创建表格
private void jButtonValiderTailleCuisineActionPerformed(java.awt.event.ActionEvent evt) {
MyTableModel dataModel;
dataModel = new MyTableModel() {
@Override public int getColumnCount() { return jSliderLongueur.getValue(); }
@Override public int getRowCount() { return jSliderLargeur.getValue();}
@Override public Object getValueAt(int row, int col) { return 0; }
};
table = new JTable(dataModel);
dataModel.setEditModel(jSliderLargeur.getValue(), jSliderLongueur.getValue());
table.setDragEnabled(false);
table.setTableHeader(null);
table.setCellSelectionEnabled(true);
table.setRowSelectionAllowed(false);
table.setColumnSelectionAllowed(false);
table.setRowHeight(40);
TableColumn column;
for (int i = 0; i < jSliderLongueur.getValue(); i++) {
column = table.getColumnModel().getColumn(i);
column.setMinWidth(40);
column.setMaxWidth(40);
}
System.out.println(dataModel.getValueAt(5, 5));
JPanel m_rootPanel = new JPanel();
JScrollPane jScrollPane1 = new JScrollPane(table);
m_rootPanel.setLayout(new BorderLayout());
jInternalFramePourTableau.setContentPane(m_rootPanel);
m_rootPanel.add(jScrollPane1, BorderLayout.CENTER);
for (int i =0; i<dataModel.getColumnCount();i++) {
table.setDefaultRenderer(table.getColumnClass(i), new MyCellRenderer());
}
table.addMouseListener(new java.awt.event.MouseAdapter() {
@Override
public void mouseClicked(java.awt.event.MouseEvent evt) {
int row = table.rowAtPoint(evt.getPoint());
int col = table.columnAtPoint(evt.getPoint());
if (row >= 0 && col >= 0) {
selectedCell[0] = row;
selectedCell[1] = col;
System.out.println("Vous avez cliquez en: " + selectedCell[0] + " " + selectedCell[1]);
}
}
});
jSliderLongueur.setEnabled(false);
jSliderLargeur.setEnabled(false);
jButtonValiderTailleCuisine.setEnabled(false);
}
可以,但是我不能编辑非灰色的单元格。因此,问题可能出在我创建表的方式上。
这是我无法使用的代码(这是我按下此按钮时的代码,它必须将所选单元格的值更改为“ TEST”):
private void jButtonChangeValueActionPerformed(java.awt.event.ActionEvent evt) {
System.out.println("CurrentCellSelected: " + selectedCell[0] + " " + selectedCell[1]);//it is the correct selectedCell
dataModel.setValueAt("TEST", selectedCell[0], selectedCell[1]);//NOT WORKING
}
当我单击按钮“ jButtonChangeValueActionPerformed”时,行dataModel.setValueAt(...)无效。
我真的希望有人能帮助我,我浪费了很多时间试图找到解决方案。
大家晚上好。
您的代码中缺少以下代码:
table.getModel().addTableModelListener(new TableModelListener() {
public void tableChanged(TableModelEvent e) {
table.setValueAt("TEST", selectedCell[0], selectedCell[1]);
}
});
@@ Arvind感谢您的回答。
我实现了,但是当我按一下按钮来编辑单元格时,我得到了一个巨大的堆栈跟踪。:
Exception in thread "AWT-EventQueue-0" java.lang.StackOverflowError
at javax.swing.table.AbstractTableModel.fireTableChanged(AbstractTableModel.java:291)
at javax.swing.table.AbstractTableModel.fireTableCellUpdated(AbstractTableModel.java:275)
at javax.swing.table.DefaultTableModel.setValueAt(DefaultTableModel.java:666)
at javax.swing.JTable.setValueAt(JTable.java:2744)
at happy_kitchen.FenAppClient$9.tableChanged(FenAppClient.java:553)
at javax.swing.table.AbstractTableModel.fireTableChanged(AbstractTableModel.java:296)
at javax.swing.table.AbstractTableModel.fireTableCellUpdated(AbstractTableModel.java:275)
at javax.swing.table.DefaultTableModel.setValueAt(DefaultTableModel.java:666)
at javax.swing.JTable.setValueAt(JTable.java:2744)
以下部分被多次写入:
at happy_kitchen.FenAppClient$9.tableChanged(FenAppClient.java:553)
at javax.swing.table.AbstractTableModel.fireTableChanged(AbstractTableModel.java:296)
at javax.swing.table.AbstractTableModel.fireTableCellUpdated(AbstractTableModel.java:275)
at javax.swing.table.DefaultTableModel.setValueAt(DefaultTableModel.java:666)
at javax.swing.JTable.setValueAt(JTable.java:2744)
编辑:
当我在tableChanged()中打印某些东西以查看它何时被调用时,它会在控制台中多次打印它,并且该框架是无法删除的。看起来它在此事件中永远循环。