Maison >Java >javaDidacticiel >Comment valider l'entrée de cellule JTable pour les valeurs entières non positives ?

Comment valider l'entrée de cellule JTable pour les valeurs entières non positives ?

DDD
DDDoriginal
2024-10-26 13:35:02638parcourir

How to Validate JTable Cell Input for Non-Positive Integer Values?

Comment valider l'entrée d'une cellule JTable pour des valeurs non valides

Lors de la définition du type de classe d'une colonne JTable en tant que sous-classe numérique spécifique, Swing rejette automatiquement l'utilisateur entrée qui ne correspond pas au type. Par exemple, si la colonne est définie comme Integer.class, les valeurs doubles sont rejetées.

Pour obtenir le même effet pour les valeurs non positives, la méthode setValueAt peut être remplacée dans le modèle de table. Cependant, cette approche à elle seule ne fournit pas de retour visuel à l'utilisateur.

Une solution plus complète consiste à utiliser un éditeur de cellules personnalisé. L'un de ces éditeurs est PositiveIntegerCellEditor, qui étend DefaultCellEditor et remplace la méthode stopCellEditing pour vérifier les valeurs négatives ou nulles. Si une valeur invalide est détectée, l'éditeur définit la bordure de la cellule en rouge et annule le processus d'édition.

<code class="java">private static class PositiveIntegerCellEditor extends DefaultCellEditor {

    private static final Border red = new LineBorder(Color.red);
    private static final Border black = new LineBorder(Color.black);
    private JTextField textField;

    public PositiveIntegerCellEditor(JTextField textField) {
        super(textField);
        this.textField = textField;
        this.textField.setHorizontalAlignment(JTextField.RIGHT);
    }

    @Override
    public boolean stopCellEditing() {
        try {
            int v = Integer.valueOf(textField.getText());
            if (v < 0) {
                throw new NumberFormatException();
            }
        } catch (NumberFormatException e) {
            textField.setBorder(red);
            return false;
        }
        return super.stopCellEditing();
    }

    @Override
    public Component getTableCellEditorComponent(JTable table,
        Object value, boolean isSelected, int row, int column) {
        textField.setBorder(black);
        return super.getTableCellEditorComponent(
            table, value, isSelected, row, column);
    }
}</code>

Pour utiliser cet éditeur, l'éditeur de cellule de la colonne du tableau peut être défini à l'aide du code suivant :

<code class="java">table.getColumnModel().getColumn(columnIndex).setCellEditor(new PositiveIntegerCellEditor(new JTextField()));</code>

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!

Déclaration:
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