diff --git a/LoadButton.java b/LoadButton.java index 30dd931..c50f872 100644 --- a/LoadButton.java +++ b/LoadButton.java @@ -21,11 +21,10 @@ public class LoadButton implements ActionListener { chargerFichier(); } - private void chargerFichier() { JFileChooser choix = new JFileChooser(System.getProperty("user.dir")); // ce placer dans le repertoire ou se situe le code pour JFIleChooser choix.setDialogTitle("Choisir un fichier"); - choix.setFileFilter(new FileNameExtensionFilter("Fichiers texte", "txt")); + choix.setFileFilter(new FileNameExtensionFilter("Fichiers gri", "gri")); int choixValide = choix.showOpenDialog(parent); if (choixValide != JFileChooser.APPROVE_OPTION) return; @@ -33,18 +32,15 @@ public class LoadButton implements ActionListener { effacerGrille(); // efface que si l'utilisateur choisit un fichier try { - FileReader fich = new FileReader(Selection); // permet de réecrire le fichier dans la grille - BufferedReader file = new BufferedReader(fich); - int a = 0; - String line; - while ((line = file.readLine()) != null && a < GRID_SIZE) { - for (int colonne = 0; colonne < Math.min(line.length(), GRID_SIZE); colonne++) { - char ch = line.charAt(colonne); - if (Character.isDigit(ch) && ch != '0') { - grid[a][colonne].setText(String.valueOf(ch)); - } + FileInputStream fich = new FileInputStream(Selection); // permet de réecrire le fichier dans la grille + DataInputStream file = new DataInputStream(fich); + for (int i = 0; i < 9; i++){ + int valeur = file.readInt(); + for(int j = 8; j >= 0; j--){ + int cell = valeur % 10; + valeur /= 10; + grid[i][j].setText(cell == 0 ? "" : String.valueOf(cell)); } - a++; } try { file.close(); diff --git a/SaveButton.java b/SaveButton.java index 567ddaf..4d4c288 100644 --- a/SaveButton.java +++ b/SaveButton.java @@ -27,33 +27,30 @@ public class SaveButton implements ActionListener { } - public void saveFichier() { + private void saveFichier() { try { - FileWriter fr = new FileWriter("GrilleNum1.txt"); - BufferedWriter fichier = new BufferedWriter(fr); + FileOutputStream fr = new FileOutputStream("Test1.gri"); + DataOutputStream fichier = new DataOutputStream(fr); + JTextField[][] texte = grid; for (int i = 0; i < GRID_SIZE; i++) { + StringBuilder build = new StringBuilder(); for (int j = 0; j < GRID_SIZE; j++) { - String value; - if (grid[i][j].getText().isEmpty()) { - value = "0"; + String value = texte[i][j].getText(); + if (value.isEmpty()) { + build.append("0"); } else { - value = grid[i][j].getText(); + build.append(value); } - fichier.write(value); } - fichier.newLine(); + String convert = build.toString(); + int write = Integer.parseInt(convert); + fichier.writeInt(write); } - try { fichier.close(); - } catch (IOException e) { - System.err.println("Erreur de fermeture"); - } - JOptionPane.showMessageDialog(null, "Grille sauvegardé avec succès.", "Succes", JOptionPane.INFORMATION_MESSAGE); + JOptionPane.showMessageDialog(null, "Grille sauvegardée avec succès.", "Succès", JOptionPane.INFORMATION_MESSAGE); } catch (IOException e) { JOptionPane.showMessageDialog(null, "Erreur lors de la sauvegarde de la grille.", "Erreur", JOptionPane.ERROR_MESSAGE); e.printStackTrace(); } } } - - diff --git a/SudokuGrid.java b/SudokuGrid.java index 8603b69..804087f 100644 --- a/SudokuGrid.java +++ b/SudokuGrid.java @@ -3,13 +3,14 @@ import java.awt.*; public class SudokuGrid extends JFrame { private static final int GRID_SIZE = 9; // Taille de la grille Sudoku 9x9 + private static final int REGION_SIZE = 3; private JTextField[][] grid; public SudokuGrid() { // Panneau pour la grille Sudoku JPanel gridPanel = new JPanel(); gridPanel.setLayout(new GridLayout(GRID_SIZE, GRID_SIZE)); // Utiliser GridLayout - gridPanel.setBackground(Color.black); // Fond vert + gridPanel.setBackground(new Color(88, 169, 191)); // Fond vert // Initialiser la grille grid = new JTextField[GRID_SIZE][GRID_SIZE]; @@ -23,6 +24,24 @@ public class SudokuGrid extends JFrame { grid[i][j].setHorizontalAlignment(JTextField.CENTER); grid[i][j].setFont(new Font("Verdana", Font.BOLD,40)); gridPanel.add(grid[i][j]); + + int top = 1; + int left = 1; + int bottom = 1; + int right = 1; + + // Vérifier si la case est sur le bord de la région horizontalement + if ((j + 1) % REGION_SIZE == 0 && j != GRID_SIZE - 1) { + right = 5; // Ajouter une bordure plus épaisse à droite + } + + // Vérifier si la case est sur le bord de la région verticalement + if ((i + 1) % REGION_SIZE == 0 && i != GRID_SIZE - 1) { + bottom = 5; // Ajouter une bordure plus épaisse en bas + } + + // Appliquer la bordure à la case + grid[i][j].setBorder(BorderFactory.createMatteBorder(top, left, bottom, right, Color.BLACK)); } } @@ -34,7 +53,7 @@ public class SudokuGrid extends JFrame { // Bouton pour sauvegarder la grille JButton save = new JButton("Sauvegarder"); - SaveButton saver = new SaveButton(GRID_SIZE,grid); + SaveButton saver = new SaveButton(GRID_SIZE,grid); save.addActionListener(saver); @@ -46,6 +65,7 @@ public class SudokuGrid extends JFrame { load.addActionListener(loader); + /* // Bouton pour vérifier la grille JButton verify = new JButton("Vérifier"); @@ -53,10 +73,11 @@ public class SudokuGrid extends JFrame { verify.addActionListener(verifyer); - + */ bouton.add(load); bouton.add(save); - bouton.add(verify); + + // bouton.add(verify); // Ajout des panneaux à la fenetre getContentPane().add(gridPanel, BorderLayout.CENTER); diff --git a/VerifButton.java b/VerifButton.java index 8c14218..dd4c672 100644 --- a/VerifButton.java +++ b/VerifButton.java @@ -1,3 +1,5 @@ +/* + import javax.swing.*; import java.awt.event.*; @@ -22,6 +24,7 @@ public class VerifButton implements ActionListener { GrilleValide(); } +} public void GrilleValide() { @@ -131,5 +134,6 @@ public class VerifButton implements ActionListener { } } } + } - + */