我试图让一个jtable包含其中一列的组合框,但它不起作用,它只是看起来像一个普通的表格单元格。目前,我正在遵循oracle的示例:http://docs.oracle.com/javase/tutorial/displayCode.html?code=http://docs.oracle.com/javase/tutorial/uiswing/examples/components/TableRenderDemoProject/src/components/TableRenderDemo.java
我尝试了这里发布的关于这个的所有主题以及各种方法,我曾经让它工作过一次,但在我尝试了不同的方法后就失去了它。我做错了什么?我没有包括所有的代码,它太长了,只是相关的部分。之前已经将clientsTable声明为jTable。
// Define Table model for clients table
class ClientsTableModel extends DefaultTableModel {
public ClientsTableModel(Vector<Vector<String>> clientsDataVector,
Vector<String> clientColumNamesVector) {
super(clientsDataVector, clientColumNamesVector);
}
@Override
public int getColumnCount() {
return clientColumNames.length;
}
@Override
public int getRowCount() {
return clientsDataVector.size();
}
@Override
public String getValueAt(int row, int column) {
return clientsDataVector.get(row).get(column);
}
@Override
public void setValueAt(Object aValue, int row, int column) {
clientsDataVector.get(row).set(column, (String) aValue);
}
@Override
public Class<?> getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
}
// create table model and add to clients table
clientColumNames = new String[] { "ID", "Name", "Type", "Address",
"Email", "Phone", "Comment" };
clientColumNamesVector = new Vector<String>(
Arrays.asList(clientColumNames));
clientsDataVector = new Vector<Vector<String>>(1, 1);
clientsTableModel = new ClientsTableModel(clientsDataVector,
clientColumNamesVector);
clientsTableModelEvent = new TableModelEvent(clientsTableModel);
clientsTableModel.addTableModelListener(new TableModelListener() {
@Override
public void tableChanged(TableModelEvent arg0) {
}
});
// create clients table and set type column to be combo box
String[] clientTypes = { "REGULAR", "GOLD", "PLATINUM" };
clientsTable = new JTable(clientsTableModel);
clientsTable.setAutoCreateRowSorter(true);
clientsTable.setFillsViewportHeight(true);
JComboBox clientsTypeComboBox = new JComboBox(clientTypes);
TableColumn clientsTypeColumn = clientsTable.getColumnModel().getColumn(2);
clientsTypeColumn.setCellEditor(new DefaultCellEditor(clientsTypeComboBox));
DefaultTableCellRenderer cellRenderer = new DefaultTableCellRenderer();
// create client scroll pane
JScrollPane clientsScrollPane = new JScrollPane(clientsTable);
GridBagConstraints gbc_clientsScrollPane = new GridBagConstraints();
gbc_clientsScrollPane.insets = new Insets(0, 0, 5, 0);
gbc_clientsScrollPane.fill = GridBagConstraints.BOTH;
gbc_clientsScrollPane.gridx = 0;
gbc_clientsScrollPane.gridy = 0;
viewClientsPanel.add(clientsScrollPane, gbc_clientsScrollPane);发布于 2013-12-03 16:16:58
它只是看起来像一个普通的表格单元格。
之所以会发生这种情况,是因为您的列有默认的呈现器。开始编辑时,列将显示为JComboBox,因为您使用JComboBox设置了DefaultCellEditor。如果你想总是以JComboBox的形式呈现单元格,你可以实现一个用于自定义单元格视图的TableCellRenderer,请阅读tutorial。下面是一个简单的例子:
import java.awt.Component;
import javax.swing.DefaultCellEditor;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableCellRenderer;
public class Example extends JFrame {
public Example() {
DefaultTableModel m = new DefaultTableModel(new Object[][]{{"2",2,3},{"1",4,5}},new Object[]{1,2,3});
JTable t = new JTable(m);
t.getColumnModel().getColumn(0).setCellEditor(new DefaultCellEditor(new JComboBox(new Object[]{"1","2"})));
t.getColumnModel().getColumn(0).setCellRenderer(getCellRenderer());
t.setRowHeight(25);
getContentPane().add(new JScrollPane(t));
pack();
}
private TableCellRenderer getCellRenderer() {
return new TableCellRenderer() {
JComboBox box = new JComboBox(new Object[]{"1","2"});
@Override
public Component getTableCellRendererComponent(JTable arg0, Object arg1,boolean arg2, boolean arg3, int arg4, int arg5) {
box.setSelectedItem(arg1);
return box;
}
};
}
public static void main(String[] args) throws InterruptedException {
Example ex = new Example();
ex.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
ex.setVisible(true);
}
}它看起来像下面这样:

发布于 2013-12-07 02:15:05
谢谢你的回答,我真的找到了问题所在。我结束了使用tableCellEditor,并制作了我的组合框来实现tablecellrenderer,这是我以前尝试过的,但我没有做的主要事情是覆盖jtable getcellrendere/编辑器方法: clientsTable = new JTable(clientsTableModel){
@Override
public TableCellEditor getCellEditor(int row, int col) {
if (col==2) return clientsTypeCellEditor;
return super.getCellEditor(row, col);
}
@Override
public TableCellRenderer getCellRenderer(int arg0, int arg1) {
// TODO Auto-generated method stub
return super.getCellRenderer(arg0, arg1);
}
};https://stackoverflow.com/questions/20334855
复制相似问题