Beibehalten des JTable-Zellen-Renderings nach der Zellenbearbeitung
In einer JTable kann die Implementierung benutzerdefinierter Zellen-Rendering- und Bearbeitungsfunktionen das Benutzererlebnis verbessern. Es ist jedoch wichtig, sicherzustellen, dass die gewünschte Formatierung auch nach Bearbeitungsvorgängen erhalten bleibt.
Das Problem
Nach dem Einrichten eines benutzerdefinierten Zellenrenderers für die Formatierung eines „Preises“ In der Spalte „Spalte“ stellten Benutzer eine Diskrepanz fest, bei der das Zahlenformat bei der Zellenbearbeitung verloren ging. In solchen Szenarien wird der Standardwert des Zellenrenderers möglicherweise nicht angewendet, nachdem die Bearbeitung festgeschrieben wurde.
Die Lösung
Um das benutzerdefinierte Rendering nach der Zellenbearbeitung beizubehalten, Es ist wichtig, die richtigen Ereignisauslöser und -klassen zu verwenden. Wenn die Bearbeitung abgeschlossen ist, erfasst die Methode „editingStopped()“ der JTable den neuen Wert über getCellEditorValue(). Das Modell wird dann mit setValueAt() benachrichtigt und sollte anschließend fireTableCellUpdated() aufrufen. Dieser umfassende Prozess ruft den Renderer auf, der erweitert werden kann, um spezielle Formatierungsanforderungen zu erfüllen.
Zusätzliche Überlegungen
Für komplexere Formatierungsanforderungen wird empfohlen, die Verwendung einer Instanz in Betracht zu ziehen des benutzerdefinierten Renderers als Editorkomponente selbst. Dies ermöglicht eine bessere Kontrolle über das Erscheinungsbild und Verhalten der Zelle und gewährleistet eine konsistente Formatierung auch nach Zelländerungen.
Beispiel
Der folgende Codeausschnitt stellt eine Beispielimplementierung bereit, die zeigt, wie das geht um Währungswerte als Zahlen in JTable-Zellen zu formatieren. Der benutzerdefinierte Renderer (CurrencyRenderer) übernimmt die Währungsformatierung, während der benutzerdefinierte Editor (CurrencyEditor) es Benutzern ermöglicht, die Werte zu bearbeiten und dabei die Formatierung beizubehalten.
import java.awt.Component; import java.awt.event.MouseEvent; import java.text.NumberFormat; import javax.swing.DefaultCellEditor; import javax.swing.JTable; import javax.swing.JTextField; import javax.swing.table.DefaultTableCellRenderer; // Custom cell renderer for currency formatting public class CurrencyRenderer extends DefaultTableCellRenderer { private NumberFormat formatter; public CurrencyRenderer(NumberFormat formatter) { this.formatter = formatter; setHorizontalAlignment(JLabel.RIGHT); } @Override public void setValue(Object value) { setText((value == null) ? "" : formatter.format(value)); } } // Custom cell editor for currency input, maintaining the formatting public class CurrencyEditor extends DefaultCellEditor { private NumberFormat formatter; private JTextField textField; public CurrencyEditor(NumberFormat formatter) { super(new JTextField()); this.formatter = formatter; textField = (JTextField) getComponent(); textField.setHorizontalAlignment(JTextField.RIGHT); textField.setBorder(null); } @Override public Object getCellEditorValue() { try { return new Double(textField.getText()); } catch (NumberFormatException e) { return Double.valueOf(0); } } @Override public Component getTableCellEditorComponent(JTable table, Object value, boolean isSelected, int row, int column) { textField.setText((value == null) ? "" : formatter.format((Double) value)); return textField; } }
Durch die Integration dieser Techniken können Entwickler eine benutzerdefinierte Zellendarstellung sicherstellen und Bearbeitungsfunktionen funktionieren nahtlos in JTable und bieten ein konsistentes und benutzerfreundliches Datenbearbeitungserlebnis.
Das obige ist der detaillierte Inhalt vonWie kann ich das benutzerdefinierte JTable-Zellenrendering nach der Zellenbearbeitung beibehalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!