Maison > Java > javaDidacticiel > Comment conserver le rendu personnalisé des cellules JTable après la modification des cellules ?

Comment conserver le rendu personnalisé des cellules JTable après la modification des cellules ?

Barbara Streisand
Libérer: 2024-12-06 12:00:32
original
617 Les gens l'ont consulté

How to Preserve Custom JTable Cell Rendering After Cell Editing?

Maintenir le rendu des cellules JTable après la modification des cellules

Dans une question précédente, l'accent était mis sur le formatage d'une colonne JTable en tant que chaîne mais avec une fonctionnalité de tri en tant que double. Suite à cette discussion, une nouvelle question se pose : Comment conserver le rendu de la cellule après avoir modifié la valeur de la cellule ?

Plus précisément, le problème est qu'après avoir utilisé un moteur de rendu de cellule personnalisé pour formater la cellule, puis implémenté un éditeur JTextField , la mise en forme du moteur de rendu personnalisé est perdue une fois la cellule modifiée. Cela soulève la question : le moteur de rendu n'est-il pas censé continuer à restituer les cellules après l'affichage initial des données ?

Résoudre le problème

Heureusement, il ne s'agit pas du fait que le moteur de rendu ne fonctionne pas comme attendu. La clé réside dans la compréhension du processus d’édition du tableau. Une fois l'édition terminée, la méthode editorStopped() de la table récupère la valeur mise à jour via getCellEditorValue() et l'utilise pour setValueAt() dans le modèle. Ceci, à son tour, déclenche fireTableCellUpdated(), invoquant le moteur de rendu prescrit. Par conséquent, remplacer le moteur de rendu par défaut devrait suffire à conserver le formatage des nombres.

Dans les cas où l'implémentation exige plus de flexibilité, l'utilisation d'une instance du moteur de rendu comme composant d'éditeur est une option viable. Voici un exemple :

// ...

table.setDefaultRenderer(Double.class, new CurrencyRenderer(nf));
table.setDefaultEditor(Double.class, new CurrencyEditor(nf));

// ...

private static class CurrencyEditor extends DefaultCellEditor {

    // ...

    @Override
    public Object getCellEditorValue() {
        // ...
    }

    @Override
    public Component getTableCellEditorComponent(JTable table,
        Object value, boolean isSelected, int row, int column) {
        // ...
    }
}
Copier après la connexion

En employant cette approche, le moteur de rendu personnalisé est utilisé à la fois pour restituer les cellules et faciliter leur édition.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal