Files
SAE21_2023/src/GMCase.java

100 lines
2.9 KiB
Java
Raw Normal View History

import java.awt.*;
import javax.swing.*;
/**
* GMCase représente une case dans une grille éditable.
* Cette classe étend JPanel et utilise un GMCaseListener 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 {
/**
* Valeur actuelle de la case
*/
private int cellValue = 0;
/**
* Texte à afficher dans la case
*/
private String displayText = "";
/**
* Bouton pour afficher le texte
*/
private JButton actionButton = new JButton(displayText);
/**
* Statut de la case
*/
protected boolean isActive = false;
private int row;
private int col;
private GMGrid grille;
/**
* Constructeur par défaut de GMCase.
* Initialise le bouton avec les propriétés nécessaires, crée un GMCaseListener et l'ajoute au bouton.
*/
public GMCase(GMGrid grille, int row, int col) {
this.grille = grille;
this.row = row;
this.col = col;
actionButton.setOpaque(false);
actionButton.setContentAreaFilled(false);
actionButton.setBorderPainted(false);
actionButton.setPreferredSize(new Dimension(50, 50));
2024-04-30 17:01:48 +02:00
Font buttonFont = actionButton.getFont();
actionButton.setFont(new Font(buttonFont.getName(), Font.PLAIN, 60));
BorderLayout gestionnaire = new BorderLayout();
setLayout(gestionnaire);
add(actionButton, BorderLayout.CENTER);
setPreferredSize(new Dimension(60, 60));
// Crée un GMCaseListener et l'ajoute au bouton
GMCaseKeyListener listener = new GMCaseKeyListener(this,this.grille,this.row,this.col);
actionButton.addKeyListener(listener);
GMCaseMouseListener mouseListener = new GMCaseMouseListener();
actionButton.addMouseListener(mouseListener);
}
/**
* 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;
}
public void setActive(boolean active) {
this.isActive = active;
if (isActive) {
setBackground(Color.CYAN);
} else {
setBackground(Color.WHITE);
}
updateDisplay();
}
}