Java 将JComboBox设置为表列不会';行不通
使用MCVE立即编辑: 我想将一个JTable单元格视为JComboBox。我在Oracle教程中试用过,但它不起作用。本教程没有说明如何更改表模型以使其正常工作。下面是代码: 表格模型:Java 将JComboBox设置为表列不会';行不通,java,swing,jtable,jcombobox,tablecelleditor,Java,Swing,Jtable,Jcombobox,Tablecelleditor,使用MCVE立即编辑: 我想将一个JTable单元格视为JComboBox。我在Oracle教程中试用过,但它不起作用。本教程没有说明如何更改表模型以使其正常工作。下面是代码: 表格模型: import javax.swing.*; import javax.swing.table.AbstractTableModel; public class TableModel extends AbstractTableModel { @Override public int getColumnCou
import javax.swing.*;
import javax.swing.table.AbstractTableModel;
public class TableModel extends AbstractTableModel {
@Override
public int getColumnCount() {
// TODO Auto-generated method stub
return 2;
}
@Override
public int getRowCount() {
// TODO Auto-generated method stub
return 2;
}
@Override
public Object getValueAt(int row, int col) {
if (row == 0) {
return 2;
} else if (col == 1 ) {
return 1;
} else {
return null;
}
}
}
以及显示组件的视图:
import java.awt.BorderLayout;
import javax.swing.*;
import javax.swing.table.TableColumn;
public class View extends JFrame {
public View() {
super();
TableModel tableModel = new TableModel();
JTable testTable = new JTable(tableModel);
JScrollPane scrollpane = new JScrollPane(testTable);
// scrollpane.setOpaque(false);
// scrollpane.getViewport().setOpaque(false);
JPanel testTablePanel = new JPanel();
testTablePanel.setBorder(
BorderFactory.createTitledBorder(BorderFactory.createEtchedBorder(), "Testkonfiguration"));
testTablePanel.setLayout(new BorderLayout());
testTablePanel.add(scrollpane);
TableColumn sportColumn = testTable.getColumnModel().getColumn(1);
JComboBox comboBox = new JComboBox();
comboBox.addItem("Snowboarding");
comboBox.addItem("Rowing");
comboBox.addItem("Chasing toddlers");
comboBox.addItem("Speed reading");
comboBox.addItem("Teaching high school");
comboBox.addItem("None");
sportColumn.setCellEditor(new DefaultCellEditor(comboBox));
add(scrollpane);
pack();
setVisible(true);
}
public static void main(String[] args) {
new View();
}
}
我必须在tablemodel中更改什么才能使其工作?在您的示例中,您不能使1列可编辑。首先需要执行此操作,例如在模型中:
@Override
public boolean isCellEditable(int rowIndex, int columnIndex) {
return columnIndex == 1;
}
此外,您的模型不能很好地处理数据,实际上无法获取数据,而且事实上是固定的,因此编辑器可能没有可能的效果。您需要覆盖setValueAt并让它更新模型的nucleus
例如,使用您的简单示例:
import java.awt.BorderLayout;
import javax.swing.*;
import javax.swing.table.AbstractTableModel;
import javax.swing.table.TableColumn;
public class View extends JFrame {
public View() {
super();
TableModel tableModel = new TableModel();
JTable testTable = new JTable(tableModel);
JScrollPane scrollpane = new JScrollPane(testTable);
// scrollpane.setOpaque(false);
// scrollpane.getViewport().setOpaque(false);
JPanel testTablePanel = new JPanel();
testTablePanel.setBorder(BorderFactory
.createTitledBorder(BorderFactory.createEtchedBorder(), "Testkonfiguration"));
testTablePanel.setLayout(new BorderLayout());
testTablePanel.add(scrollpane);
TableColumn sportColumn = testTable.getColumnModel().getColumn(1);
JComboBox<String> comboBox = new JComboBox<>();
comboBox.addItem("Snowboarding");
comboBox.addItem("Rowing");
comboBox.addItem("Chasing toddlers");
comboBox.addItem("Speed reading");
comboBox.addItem("Teaching high school");
comboBox.addItem("None");
sportColumn.setCellEditor(new DefaultCellEditor(comboBox));
setDefaultCloseOperation(EXIT_ON_CLOSE);
add(scrollpane);
pack();
setVisible(true);
}
public static void main(String[] args) {
new View();
}
}
如果你能创建并发布一个有效的——一个小的可编译且可运行的程序,小到可以在这里完全发布,那么对我们来说最有帮助的是什么呢。请考虑这样做。我现在写了一个HoVrravtFulfFeels.thanks@Phreneticus您只需要实现正确的模型。首先,对于第1列,它应该返回您添加到组合框中的一个值。第二:您需要实现方法
setValueAt(Object aValue,int rowIndex,int columnIndex)
来存储您在组合框中选择的值。您还需要实现isCellEditable(int-rowIndex,int-columndex)
,它为索引为1的列返回true。就是这样,我忘了调用setValueAt()facepalm,谢谢!我的代码现在可以工作了,但是,只要我单击该列中的表单元格,我就只能看到表列由组合框组成。只要我选择组合框的另一个选项,我就不再看到属于组合框的箭头。是否有办法在每个单元格上始终显示此箭头?
class TableModel extends AbstractTableModel {
Object[][] innerModel = new Object[][]{{2, 1}, {2, null}};
public TableModel() {
}
@Override
public int getColumnCount() {
return 2;
}
@Override
public int getRowCount() {
return innerModel.length;
}
@Override
public Object getValueAt(int row, int col) {
return innerModel[row][col];
}
@Override
public void setValueAt(Object aValue, int rowIndex, int columnIndex) {
innerModel[rowIndex][columnIndex] = aValue;
fireTableCellUpdated(rowIndex, columnIndex);
}
@Override
public boolean isCellEditable(int rowIndex, int columnIndex) {
return columnIndex == 1;
}
}