0

2つの列を持つJTableがあります。2番目の列には、各行に異なるエディター(JTextField、JComboBox、およびCheckComboBox)があります。これはこれまでのところ正常に機能しますが、JTable全体を元の状態に戻す(すべての変更をリセットする)リセットオプションを実装しました。

私が現在直面している問題は、ComboBoxのインデックスをプログラムで変更するとsetSelectedIndex、モデルがその変更を実行し、テーブルのfireTableDataChangedによっても受信されても​​、GUIに結果が表示されないことTableModelListenerです。変更されたComboBoxを検索すると、正しいインデックスも取得されますが、GUIには表示されません。私も方法を試しましたがrevalidate、変更はupdateUIありrepaintませんでした。

問題はそのアーキテクチャにあるかもしれません(多分レンダラー?)。これが私のエディター/レンダラークラスです。

class VEachRowEditor implements TableCellEditor, TableCellRenderer {

protected Hashtable<Integer, TableCellEditor> editors;
protected TableCellEditor editor, defaultEditor, renderer;
JTable table;
VEachRowEditorManager rowmanager;

public VEachRowEditor(JTable table, VEachRowEditorManager rowmanager) {
    this.table = table;
    editors = new Hashtable<Integer, TableCellEditor>();
    defaultEditor = new DefaultCellEditor(new JTextField());
    this.rowmanager = rowmanager;
}

public void setEditorAt(int row, TableCellEditor editor) {
    if (editor instanceof DefaultCellEditor)
        ((DefaultCellEditor) editor).setClickCountToStart(1);
    editors.put(new Integer(row), editor);
}

public Component getTableCellEditorComponent(JTable table, Object value,
        boolean isSelected, int row, int column) {
    editor = (TableCellEditor) editors.get(new Integer(row));
    if (editor == null) {
        editor = defaultEditor;
    }
    return editor.getTableCellEditorComponent(table, value, isSelected,
            row, column);
}

public Object getCellEditorValue() {
    return editor.getCellEditorValue();
}

public final boolean stopCellEditing() {
    return editor.stopCellEditing();
}

public void cancelCellEditing() {
    editor.cancelCellEditing();
}

public boolean isCellEditable(EventObject anEvent) {
    selectEditor((MouseEvent) anEvent);
    return editor.isCellEditable(anEvent);
}

public void addCellEditorListener(CellEditorListener l) {
    editor.addCellEditorListener(l);
}

public void removeCellEditorListener(CellEditorListener l) {
    editor.removeCellEditorListener(l);
}

public boolean shouldSelectCell(EventObject anEvent) {
    selectEditor((MouseEvent) anEvent);
    return editor.shouldSelectCell(anEvent);
}

protected void selectEditor(MouseEvent e) {
    int row;
    if (e == null) {
        row = table.getSelectionModel().getAnchorSelectionIndex();
    } else {
        row = table.rowAtPoint(e.getPoint());
    }
    editor = (TableCellEditor) editors.get(new Integer(row));
    if (editor == null) {
        System.out.println(editor);
        editor = defaultEditor;
    }
}

@Override
public Component getTableCellRendererComponent(JTable table, Object value,
        boolean isSelected, boolean hasFocus, int row, int column) {
    renderer = (TableCellEditor) editors.get(new Integer(row));
    if (renderer == null) {
        renderer = defaultEditor;
    }

    return renderer.getTableCellEditorComponent(table, value, isSelected,
            row, column);
}

}

getTableCellEditorComponent間違っていますか?

rowmanager、すべてのモデルのすべてのJComboBoxesとCheckComboBoxesを保持します。

4

1 に答える 1

2

setSelectedIndexを使用してComboBoxのインデックスをプログラムで変更すると、GUIに結果が表示されません。

レンダラーとエディターは、モデル内のデータを表示するだけです。エディタコンポーネントをリセットしないでください。

モデルのデータをリセットします。すなわち>

table.setValueAt(...); // or
table.getModel().setValueAt(...);
于 2013-03-26T17:24:35.470 に答える