Files
SAE21_2023/src/GMCase.java

65 lines
2.1 KiB
Java
Raw Normal View History

import java.awt.*;
import javax.swing.*;
/**
* GridMakerCase représente une case dans une grille éditable.
* Cette classe étend JPanel et utilise un GridMakerCaseListener pour gérer les événements de touche.
* @version 1.0
* @author Moncef STITI
* @author Marco ORFAO
*/
2024-04-29 16:26:16 +02:00
public class GMCase extends JPanel {
private int cellValue = 0; // Valeur actuelle de la case
private String displayText = ""; // Texte à afficher dans la case
private JButton actionButton = new JButton(displayText); // Bouton pour afficher le texte
/**
* Constructeur par défaut de GridMakerCase.
* Initialise le bouton avec les propriétés nécessaires, crée un GridMakerCaseListener et l'ajoute au bouton.
*/
2024-04-29 16:26:16 +02:00
public GMCase() {
actionButton.setOpaque(false);
actionButton.setContentAreaFilled(false);
actionButton.setBorderPainted(false);
actionButton.setPreferredSize(new Dimension(50, 50));
BorderLayout gestionnaire = new BorderLayout();
setLayout(gestionnaire);
add(actionButton, BorderLayout.CENTER);
setPreferredSize(new Dimension(60, 60));
// Crée un GridMakerCaseListener et l'ajoute au bouton
2024-04-29 16:26:16 +02:00
GMCaseListener listener = new GMCaseListener(this);
actionButton.addKeyListener(listener);
}
/**
* Met à jour l'affichage de la case avec la valeur actuelle.
*/
public void updateDisplay() {
actionButton.setText(displayText.isEmpty() ? "" : displayText);
revalidate();
repaint();
}
/**
* Définit la valeur de la case et met à jour son affichage.
* @param value La nouvelle valeur de la case.
*/
public void setCellValue(int value) {
this.cellValue = value;
this.displayText = (value == 0) ? "" : String.valueOf(value); // Mettre à jour avec une chaîne vide si la valeur est 0
updateDisplay();
}
/**
* Récupère la valeur actuelle de la case.
* @return La valeur actuelle de la case.
*/
public int getCellValue() {
return this.cellValue;
}
}