Java 在JTable中,编辑单元格唯一JComboxes时更新显示的项
我有一个GUI,其中有一列JComboxes,每个都是唯一的。我真的不明白我在做什么,所以在一个非常长的路障序列中,最新的一个是当一个框被编辑时,它不会显示新选择的值。如果再次选择该框,单元格中的值将更新为先前选择的值,因此可能只是表/渲染器不更新的问题 我怀疑我可能需要在某个地方为每个组合框注册一个侦听器,但我不知道在哪个类上注册哪种类型的侦听器 以下是SSCCE,它尽可能简洁地说明了目前的设计:Java 在JTable中,编辑单元格唯一JComboxes时更新显示的项,java,swing,jtable,jcombobox,tablecellrenderer,Java,Swing,Jtable,Jcombobox,Tablecellrenderer,我有一个GUI,其中有一列JComboxes,每个都是唯一的。我真的不明白我在做什么,所以在一个非常长的路障序列中,最新的一个是当一个框被编辑时,它不会显示新选择的值。如果再次选择该框,单元格中的值将更新为先前选择的值,因此可能只是表/渲染器不更新的问题 我怀疑我可能需要在某个地方为每个组合框注册一个侦听器,但我不知道在哪个类上注册哪种类型的侦听器 以下是SSCCE,它尽可能简洁地说明了目前的设计: import java.awt.Component; import java.util.Arra
import java.awt.Component;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import javax.swing.DefaultCellEditor;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JTable;
import javax.swing.border.EmptyBorder;
import javax.swing.event.TableModelListener;
import javax.swing.table.TableCellEditor;
import javax.swing.table.TableCellRenderer;
import javax.swing.table.TableColumn;
import javax.swing.table.TableModel;
@SuppressWarnings("serial")
public class ComboBoxTableGUI extends JFrame {
public List<SampleCollection> masterList;
public static void main(String[] args) {
new ComboBoxTableGUI();
}
public ComboBoxTableGUI() {
// create a collection of 10 collections, each with 1-10 Strings
masterList = new ArrayList<SampleCollection>();
Random rnd = new Random();
for (int i = 0; i < 10; i++) {
SampleCollection sc = new SampleCollection("Option " + i + ":");
int choices = rnd.nextInt(9) + 1;
for (int j = 0; j < choices; j++) {
sc.choices.add("Choice " + j);
}
sc.selectedChoice = sc.choices.get(0);
masterList.add(sc);
}
this.setSize(500, 500);
this.setLocationRelativeTo(null);
TableModel optionTableModel = new OptionTableModel();
JTableWithCustomEditors optionsTable = new JTableWithCustomEditors(optionTableModel);
this.add(optionsTable);
TableColumn optionCol = optionsTable.getColumnModel().getColumn(1);
optionCol.setCellRenderer(new CustomComboBoxRenderer());
List<TableCellEditor> editors = new ArrayList<TableCellEditor>();
for (SampleCollection collection : masterList) {
JComboBox<String> cb = new JComboBox<String>();
for (String choice : collection.choices) {
cb.addItem(choice);
}
DefaultCellEditor editor = new DefaultCellEditor(cb);
editors.add(editor);
}
optionsTable.editors = editors;
this.setVisible(true);
}
public class SampleCollection {
public String name, selectedChoice;
public List<String> choices;
public SampleCollection(String name) {
this.name = name;
this.choices = new ArrayList<String>();
}
}
public class JTableWithCustomEditors extends JTable {
public List<TableCellEditor> editors;
public JTableWithCustomEditors(TableModel model) {
super(model); // lol
}
@Override
public TableCellEditor getCellEditor(int row, int column) {
if (column == 1)
return editors.get(row);
else
return super.getCellEditor(row, column);
}
}
class CustomComboBoxRenderer extends JComboBox<String> implements
TableCellRenderer {
public CustomComboBoxRenderer() {
setBorder(new EmptyBorder(0, 0, 0, 0));
}
public Component getTableCellRendererComponent(JTable table,
Object value, boolean isSelected, boolean hasFocus, int row,
int column) {
removeAllItems();
addItem(((SampleCollection) value).selectedChoice);
this.setSelectedIndex(0);
return this;
}
}
public class OptionTableModel implements TableModel {
private List<TableModelListener> listeners;
public OptionTableModel() {
listeners = new ArrayList<TableModelListener>();
}
@Override
public void addTableModelListener(TableModelListener l) {
listeners.add(l);
}
@Override
public Class<?> getColumnClass(int columnIndex) {
if (columnIndex == 1)
return SampleCollection.class;
else
return String.class;
}
@Override
public int getColumnCount() {
return 2;
}
@Override
public String getColumnName(int columnIndex) {
if (columnIndex == 0)
return "Name";
else
return "Selection";
}
@Override
public int getRowCount() {
if (masterList == null)
return 0;
else
return masterList.size();
}
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
if (columnIndex == 0)
return masterList.get(rowIndex).name;
else
return masterList.get(rowIndex);// also tried .choices
}
@Override
public boolean isCellEditable(int rowIndex, int columnIndex) {
if (columnIndex == 1)
return true;
else
return false;
}
@Override
public void removeTableModelListener(TableModelListener l) {
listeners.remove(l);
}
@Override
public void setValueAt(Object aValue, int rowIndex, int columnIndex) {
// the values are grabbed when the user clicks an OK button, right
// now I just need to get it rendering
}
}
}
导入java.awt.Component;
导入java.util.ArrayList;
导入java.util.List;
导入java.util.Random;
导入javax.swing.DefaultCellEditor;
导入javax.swing.JComboBox;
导入javax.swing.JFrame;
导入javax.swing.JTable;
导入javax.swing.border.EmptyBorder;
导入javax.swing.event.TableModelListener;
导入javax.swing.table.TableCellEditor;
导入javax.swing.table.TableCellRenderer;
导入javax.swing.table.TableColumn;
导入javax.swing.table.TableModel;
@抑制警告(“串行”)
公共类ComboBoxTableGUI扩展了JFrame{
公开名单总名单;
公共静态void main(字符串[]args){
新ComboxTableGUI();
}
公共comboxTableGUI(){
//创建10个集合的集合,每个集合包含1-10个字符串
主列表=新的ArrayList();
随机rnd=新随机();
对于(int i=0;i<10;i++){
SampleCollection sc=新的SampleCollection(“选项“+i+”:”);
int choices=rnd.nextInt(9)+1;
for(int j=0;j
您的TableModel实现不正确
首先,数据应该存储在模型中,而不是作为类中的实例变量