Ajout de la cohabitation de chiffre
This commit is contained in:
@@ -2,7 +2,7 @@ import java.awt.event.*;
|
||||
import javax.swing.*;
|
||||
import java.awt.Color;
|
||||
import java.util.ArrayList;
|
||||
|
||||
import java.awt.Font;
|
||||
|
||||
public class TextFilter extends KeyAdapter {
|
||||
|
||||
@@ -12,12 +12,14 @@ public class TextFilter extends KeyAdapter {
|
||||
private int row;
|
||||
private int col;
|
||||
private ArrayList<Integer> bad_numbers = new ArrayList<Integer>();
|
||||
private boolean errorDetected = true;
|
||||
private int status;
|
||||
|
||||
|
||||
public TextFilter (JTextField t,int GRID_SIZE, JTextField[][] grid, int i, int j) {
|
||||
public TextFilter (JTextField t,int GRID_SIZE, JTextField[][] grid, int i, int j, int status) {
|
||||
|
||||
this.Text = t;
|
||||
this.GRID_SIZE = GRID_SIZE;
|
||||
this.status = status;
|
||||
this.grid = grid;
|
||||
this.row = i;
|
||||
this.col = j;
|
||||
@@ -31,35 +33,67 @@ public class TextFilter extends KeyAdapter {
|
||||
char chiffre = e.getKeyChar();
|
||||
int taille = this.Text.getText().length();
|
||||
|
||||
if ( ((chiffre < '0') || (chiffre > '9')) && (chiffre != KeyEvent.VK_BACK_SPACE)) {
|
||||
// Si la longueur du texte est égale à 3 après l'ajout du chiffre, définir la taille de la police à 20
|
||||
if (taille > 1) {
|
||||
Text.setFont(new Font("Verdana", Font.BOLD, 20));
|
||||
} else {
|
||||
|
||||
Text.setFont(new Font("Verdana", Font.BOLD, 40));
|
||||
}
|
||||
|
||||
if ( ((chiffre < '1') || (chiffre > '9')) && (chiffre != KeyEvent.VK_BACK_SPACE)) {
|
||||
|
||||
e.consume(); // ignorer l'événement
|
||||
}
|
||||
|
||||
if ( ((chiffre >= '0') && (chiffre <= '9')) && (chiffre != KeyEvent.VK_ENTER)) {
|
||||
|
||||
GrilleValide(chiffre);
|
||||
}
|
||||
if (status == 2){
|
||||
if (errorDetected) {
|
||||
if ((chiffre >= '1') && (chiffre <= '9')) {
|
||||
GrilleValide(chiffre);
|
||||
}
|
||||
} else {
|
||||
e.consume(); // empêcher la saisie de chiffres lorsque qu'une erreur est détectée
|
||||
}
|
||||
|
||||
if ((!bad_numbers.isEmpty()) && (chiffre == KeyEvent.VK_BACK_SPACE)) {
|
||||
if ((!bad_numbers.isEmpty()) && (chiffre == KeyEvent.VK_BACK_SPACE)) {
|
||||
Text.setBackground(Color.white);
|
||||
while (!bad_numbers.isEmpty()) {
|
||||
grid[bad_numbers.removeFirst()][bad_numbers.removeFirst()].setBackground(Color.white);
|
||||
}
|
||||
errorDetected = true; // Réinitialiser errorDetected après avoir corrigé les erreurs
|
||||
}
|
||||
|
||||
Text.setBackground(Color.white);
|
||||
if ( taille >= 4) {
|
||||
|
||||
while(!bad_numbers.isEmpty()) {
|
||||
e.consume();
|
||||
}
|
||||
} else if(status == 1){
|
||||
if ( taille > 1 && ((chiffre >= '1') && (chiffre <= '9')) && (chiffre != KeyEvent.VK_ENTER)) {
|
||||
|
||||
grid[bad_numbers.removeFirst()][bad_numbers.removeFirst()].setBackground(Color.white);
|
||||
}
|
||||
GrilleValide(chiffre);
|
||||
}
|
||||
|
||||
if ((!bad_numbers.isEmpty()) && (chiffre == KeyEvent.VK_BACK_SPACE)) {
|
||||
|
||||
Text.setBackground(Color.white);
|
||||
|
||||
while(!bad_numbers.isEmpty()) {
|
||||
|
||||
grid[bad_numbers.removeFirst()][bad_numbers.removeFirst()].setBackground(Color.white);
|
||||
}
|
||||
}
|
||||
|
||||
if ( taille >= 1 ) {
|
||||
|
||||
e.consume();
|
||||
}
|
||||
}
|
||||
|
||||
if ( (bad_numbers.isEmpty()) && (chiffre == KeyEvent.VK_BACK_SPACE)) {
|
||||
|
||||
Coloriage();
|
||||
}
|
||||
|
||||
if ( taille >= 1 ) {
|
||||
|
||||
e.consume();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -77,7 +111,7 @@ public class TextFilter extends KeyAdapter {
|
||||
this.grid[row][col].setBackground(Color.red);
|
||||
this.bad_numbers.add(row2);
|
||||
this.bad_numbers.add(col);
|
||||
|
||||
errorDetected = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -90,6 +124,7 @@ public class TextFilter extends KeyAdapter {
|
||||
this.grid[row][col].setBackground(Color.red);
|
||||
this.bad_numbers.add(row2);
|
||||
this.bad_numbers.add(col);
|
||||
errorDetected = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -104,6 +139,7 @@ public class TextFilter extends KeyAdapter {
|
||||
this.grid[row][col].setBackground(Color.red);
|
||||
this.bad_numbers.add(row);
|
||||
this.bad_numbers.add(col2);
|
||||
errorDetected = false;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -117,6 +153,7 @@ public class TextFilter extends KeyAdapter {
|
||||
this.grid[row][col].setBackground(Color.red);
|
||||
this.bad_numbers.add(row);
|
||||
this.bad_numbers.add(col2);
|
||||
errorDetected = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -138,6 +175,7 @@ public class TextFilter extends KeyAdapter {
|
||||
this.grid[row][col].setBackground(Color.red);
|
||||
this.bad_numbers.add(row2);
|
||||
this.bad_numbers.add(col2);
|
||||
errorDetected = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user