ajout des parametres dans la base de donnée
This commit is contained in:
@@ -1,80 +1,96 @@
|
|||||||
package linea;
|
package linea;
|
||||||
|
|
||||||
import java.sql.Connection;
|
import java.sql.*;
|
||||||
import java.sql.DriverManager;
|
|
||||||
import java.sql.PreparedStatement;
|
|
||||||
import java.sql.SQLException;
|
|
||||||
import java.sql.Statement;
|
|
||||||
|
|
||||||
public class GestionnaireBDD {
|
public class GestionnaireBDD {
|
||||||
|
|
||||||
private Connection conn = null;
|
private Connection conn = null;
|
||||||
private static final String DB_FILE = "linea_scores.db";
|
// On utilise une base de données SQLite, qui est un simple fichier.
|
||||||
|
private final String DB_URL = "jdbc:sqlite:linea.db";
|
||||||
|
|
||||||
public GestionnaireBDD() {
|
public GestionnaireBDD() {
|
||||||
try {
|
try {
|
||||||
// URL de connexion pour SQLite
|
// Le pilote JDBC pour SQLite doit être ajouté à votre projet.
|
||||||
String url = "jdbc:sqlite:" + DB_FILE;
|
Class.forName("org.sqlite.JDBC");
|
||||||
// Établir la connexion
|
conn = DriverManager.getConnection(DB_URL);
|
||||||
conn = DriverManager.getConnection(url);
|
|
||||||
System.out.println("Connexion à la base de données SQLite établie.");
|
System.out.println("Connexion à la base de données SQLite établie.");
|
||||||
// S'assurer que la table pour les scores existe
|
|
||||||
creerTableSiNecessaire();
|
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
System.err.println("Erreur de connexion à la base de données : " + e.getMessage());
|
System.out.println("Erreur de connexion à la BDD : " + e.getMessage());
|
||||||
|
} catch (ClassNotFoundException e) {
|
||||||
|
System.out.println("Le pilote JDBC SQLite n'a pas été trouvé. Veuillez l'ajouter à votre projet.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void initialiserBaseDeDonnees() {
|
||||||
private void creerTableSiNecessaire() {
|
// Crée les tables si elles n'existent pas et insère les données de difficulté.
|
||||||
String sql = "CREATE TABLE IF NOT EXISTS parties (\n"
|
|
||||||
+ " id INTEGER PRIMARY KEY AUTOINCREMENT,\n"
|
|
||||||
+ " duree_secondes INTEGER NOT NULL,\n"
|
|
||||||
+ " campagne_id INTEGER NOT NULL,\n"
|
|
||||||
+ " difficulte_id INTEGER NOT NULL,\n"
|
|
||||||
+ " score INTEGER NOT NULL,\n"
|
|
||||||
+ " date_partie TIMESTAMP DEFAULT CURRENT_TIMESTAMP\n"
|
|
||||||
+ ");";
|
|
||||||
|
|
||||||
// 'try-with-resources' assure que le Statement est bien fermé
|
|
||||||
try (Statement stmt = conn.createStatement()) {
|
try (Statement stmt = conn.createStatement()) {
|
||||||
stmt.execute(sql);
|
// Table pour les difficultés
|
||||||
|
stmt.execute("CREATE TABLE IF NOT EXISTS difficultes (" +
|
||||||
|
"id_difficulte INT PRIMARY KEY, " +
|
||||||
|
"vitesse REAL NOT NULL, " +
|
||||||
|
"pente REAL NOT NULL)");
|
||||||
|
|
||||||
|
// Table pour les scores des parties
|
||||||
|
stmt.execute("CREATE TABLE IF NOT EXISTS parties (" +
|
||||||
|
"id INTEGER PRIMARY KEY AUTOINCREMENT, " +
|
||||||
|
"duree INT, " +
|
||||||
|
"campagne_id INT, " +
|
||||||
|
"difficulte_id INT, " +
|
||||||
|
"score INT, " +
|
||||||
|
"date_partie TIMESTAMP DEFAULT CURRENT_TIMESTAMP)");
|
||||||
|
|
||||||
|
// Insertion des valeurs de difficulté par défaut
|
||||||
|
// L'instruction "INSERT OR IGNORE" est spécifique à SQLite et évite les doublons.
|
||||||
|
stmt.execute("INSERT OR IGNORE INTO difficultes (id_difficulte, vitesse, pente) VALUES (1, 6, 20);");
|
||||||
|
stmt.execute("INSERT OR IGNORE INTO difficultes (id_difficulte, vitesse, pente) VALUES (2, 7, 45);");
|
||||||
|
stmt.execute("INSERT OR IGNORE INTO difficultes (id_difficulte, vitesse, pente) VALUES (3, 8, 70);");
|
||||||
|
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
System.err.println("Erreur lors de la création de la table : " + e.getMessage());
|
System.out.println("Erreur lors de l'initialisation de la base de données : " + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public double[] getParametresDifficulte(int difficulteId) {
|
||||||
public void enregistrerPartie(int dureePartie, int idCampagne, int idDifficulte, int score) {
|
// Par défaut (si non trouvé), on retourne les valeurs pour la difficulté 1.
|
||||||
if (conn == null) {
|
double[] params = {6.0, 20.0};
|
||||||
System.err.println("Impossible d'enregistrer la partie : pas de connexion à la BDD.");
|
String sql = "SELECT vitesse, pente FROM difficultes WHERE id_difficulte = ?";
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
String sql = "INSERT INTO parties(duree_secondes, campagne_id, difficulte_id, score) VALUES(?,?,?,?)";
|
|
||||||
|
|
||||||
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
|
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
|
||||||
pstmt.setInt(1, dureePartie);
|
pstmt.setInt(1, difficulteId);
|
||||||
pstmt.setInt(2, idCampagne);
|
ResultSet rs = pstmt.executeQuery();
|
||||||
pstmt.setInt(3, idDifficulte);
|
|
||||||
pstmt.setInt(4, score);
|
if (rs.next()) {
|
||||||
pstmt.executeUpdate();
|
params[0] = rs.getDouble("vitesse");
|
||||||
System.out.println("Partie enregistrée avec succès ! Score : " + score);
|
params[1] = rs.getDouble("pente");
|
||||||
|
}
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
System.err.println("Erreur lors de l'enregistrement de la partie : " + e.getMessage());
|
System.out.println("Erreur lors de la récupération des paramètres de difficulté : " + e.getMessage());
|
||||||
}
|
}
|
||||||
|
return params;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void enregistrerPartie(int dureePartie, int idCampagneActive, int difficulteActive, int score) {
|
||||||
|
String sql = "INSERT INTO parties(duree, campagne_id, difficulte_id, score) VALUES(?,?,?,?)";
|
||||||
|
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
|
||||||
|
pstmt.setInt(1, dureePartie);
|
||||||
|
pstmt.setInt(2, idCampagneActive);
|
||||||
|
pstmt.setInt(3, difficulteActive);
|
||||||
|
pstmt.setInt(4, score);
|
||||||
|
pstmt.executeUpdate();
|
||||||
|
System.out.println("Partie enregistrée avec succès.");
|
||||||
|
} catch (SQLException e) {
|
||||||
|
System.out.println("Erreur lors de l'enregistrement de la partie : " + e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void fermerConnexion() {
|
public void fermerConnexion() {
|
||||||
try {
|
try {
|
||||||
if (conn != null && !conn.isClosed()) {
|
if (conn != null) {
|
||||||
conn.close();
|
conn.close();
|
||||||
System.out.println("Connexion à la base de données fermée.");
|
System.out.println("Connexion BDD fermée.");
|
||||||
}
|
}
|
||||||
} catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
System.err.println("Erreur lors de la fermeture de la connexion BDD : " + ex.getMessage());
|
System.out.println(ex.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -45,7 +45,7 @@ public class Jeu implements KeyListener, ActionListener {
|
|||||||
menuCampagne = new MenuCampagne(this);
|
menuCampagne = new MenuCampagne(this);
|
||||||
|
|
||||||
// Initialisation initiale
|
// Initialisation initiale
|
||||||
resetPartie();
|
resetPartie(6,20);
|
||||||
|
|
||||||
// On ajoute l'action au bouton "Retour" de la ZoneDessin (Game Over)
|
// On ajoute l'action au bouton "Retour" de la ZoneDessin (Game Over)
|
||||||
ecran.btnRetour.addActionListener(new ActionListener() {
|
ecran.btnRetour.addActionListener(new ActionListener() {
|
||||||
@@ -106,14 +106,13 @@ public class Jeu implements KeyListener, ActionListener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void lancerPartie() {
|
public void lancerPartie() {
|
||||||
resetPartie();
|
|
||||||
layout.show(conteneurPrincipal, "JEU");
|
layout.show(conteneurPrincipal, "JEU");
|
||||||
ecran.setFocusable(true);
|
ecran.setFocusable(true);
|
||||||
ecran.requestFocusInWindow();
|
ecran.requestFocusInWindow();
|
||||||
horloge.start();
|
horloge.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void resetPartie() {
|
public void resetPartie(double vitesse, double pente) {
|
||||||
if(horloge != null) {
|
if(horloge != null) {
|
||||||
horloge.stop();
|
horloge.stop();
|
||||||
}
|
}
|
||||||
@@ -123,7 +122,7 @@ public class Jeu implements KeyListener, ActionListener {
|
|||||||
demiCercleAvant = new Cercle(90, -180);
|
demiCercleAvant = new Cercle(90, -180);
|
||||||
demiCercleArriere = new Cercle(90, 180);
|
demiCercleArriere = new Cercle(90, 180);
|
||||||
|
|
||||||
laligne = new Ligne();
|
laligne = new Ligne(vitesse, pente);
|
||||||
|
|
||||||
demiCercleArriere.setCouleur(new Color(0.8f, 0.0f, 0.0f));
|
demiCercleArriere.setCouleur(new Color(0.8f, 0.0f, 0.0f));
|
||||||
demiCercleAvant.setCouleur(new Color(1.0f, 0.2f, 0.2f));
|
demiCercleAvant.setCouleur(new Color(1.0f, 0.2f, 0.2f));
|
||||||
@@ -139,6 +138,7 @@ public class Jeu implements KeyListener, ActionListener {
|
|||||||
labScore.setText("<html><h3>score : 0</h3></html>");
|
labScore.setText("<html><h3>score : 0</h3></html>");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
ecran.traiterBoucleAnimation();
|
ecran.traiterBoucleAnimation();
|
||||||
|
|||||||
Reference in New Issue
Block a user