Correction des problèmes de scintillement dans l'interface
This commit is contained in:
54
jeu.c
54
jeu.c
@@ -11,15 +11,32 @@ void dessinerGrille(struct EtatJeu etatJeu) {
|
|||||||
int i, j;
|
int i, j;
|
||||||
int largeurFenetre = 800;
|
int largeurFenetre = 800;
|
||||||
int hauteurFenetre = 600;
|
int hauteurFenetre = 600;
|
||||||
int marge = 50; /* Marge pour éviter les bords */
|
int marge = 50;
|
||||||
|
|
||||||
/* Calculer la taille de case en prenant le minimum entre largeur et hauteur */
|
/* Effacer l'écran avant tout dessin */
|
||||||
|
EffacerEcran(CouleurParNom("white"));
|
||||||
|
|
||||||
|
/* Afficher le tour du joueur actuel */
|
||||||
|
ChoisirCouleurDessin(CouleurParNom("black"));
|
||||||
|
char message[50];
|
||||||
|
sprintf(message, "Tour du Joueur %d", etatJeu.tourJoueur);
|
||||||
|
EcrireTexte(300, 30, message, 2);
|
||||||
|
|
||||||
|
/* Afficher la couleur du joueur */
|
||||||
|
if (etatJeu.tourJoueur == 1) {
|
||||||
|
ChoisirCouleurDessin(CouleurParNom("blue"));
|
||||||
|
EcrireTexte(500, 30, "(Bleu)", 2);
|
||||||
|
} else {
|
||||||
|
ChoisirCouleurDessin(CouleurParNom("red"));
|
||||||
|
EcrireTexte(500, 30, "(Rouge)", 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Le reste du code de dessin de la grille reste identique */
|
||||||
int tailleCase = (largeurFenetre - 2 * marge) / etatJeu.tailleGrille;
|
int tailleCase = (largeurFenetre - 2 * marge) / etatJeu.tailleGrille;
|
||||||
if (tailleCase * etatJeu.tailleGrille > (hauteurFenetre - 2 * marge)) {
|
if (tailleCase * etatJeu.tailleGrille > (hauteurFenetre - 2 * marge)) {
|
||||||
tailleCase = (hauteurFenetre - 2 * marge) / etatJeu.tailleGrille;
|
tailleCase = (hauteurFenetre - 2 * marge) / etatJeu.tailleGrille;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Calculer les positions de départ pour centrer la grille */
|
|
||||||
int startX = (largeurFenetre - (tailleCase * etatJeu.tailleGrille)) / 2;
|
int startX = (largeurFenetre - (tailleCase * etatJeu.tailleGrille)) / 2;
|
||||||
int startY = (hauteurFenetre - (tailleCase * etatJeu.tailleGrille)) / 2;
|
int startY = (hauteurFenetre - (tailleCase * etatJeu.tailleGrille)) / 2;
|
||||||
|
|
||||||
@@ -59,26 +76,20 @@ void gererClicSouris(struct EtatJeu *etatJeu) {
|
|||||||
int startX = (largeurFenetre - (tailleCase * etatJeu->tailleGrille)) / 2;
|
int startX = (largeurFenetre - (tailleCase * etatJeu->tailleGrille)) / 2;
|
||||||
int startY = (hauteurFenetre - (tailleCase * etatJeu->tailleGrille)) / 2;
|
int startY = (hauteurFenetre - (tailleCase * etatJeu->tailleGrille)) / 2;
|
||||||
|
|
||||||
/* Ajuster les coordonnées du clic en fonction du décalage de la grille */
|
|
||||||
x -= startX;
|
x -= startX;
|
||||||
y -= startY;
|
y -= startY;
|
||||||
|
|
||||||
/* Calculer les indices de la grille */
|
|
||||||
int i = y / tailleCase;
|
int i = y / tailleCase;
|
||||||
int j = x / tailleCase;
|
int j = x / tailleCase;
|
||||||
|
|
||||||
printf("Processing click at: (%d, %d) -> Grid position: (%d, %d)\n", x, y, i, j);
|
|
||||||
|
|
||||||
if (i >= 0 && i < etatJeu->tailleGrille &&
|
if (i >= 0 && i < etatJeu->tailleGrille &&
|
||||||
j >= 0 && j < etatJeu->tailleGrille &&
|
j >= 0 && j < etatJeu->tailleGrille &&
|
||||||
etatJeu->grille[i][j] == 0) {
|
etatJeu->grille[i][j] == 0) {
|
||||||
|
|
||||||
etatJeu->grille[i][j] = etatJeu->tourJoueur;
|
etatJeu->grille[i][j] = etatJeu->tourJoueur;
|
||||||
printf("Placed mark for player %d at position (%d, %d)\n",
|
|
||||||
etatJeu->tourJoueur, i, j);
|
|
||||||
|
|
||||||
etatJeu->tourJoueur = (etatJeu->tourJoueur == 1) ? 2 : 1;
|
etatJeu->tourJoueur = (etatJeu->tourJoueur == 1) ? 2 : 1;
|
||||||
|
|
||||||
|
EffacerEcran(CouleurParNom("white"));
|
||||||
dessinerGrille(*etatJeu);
|
dessinerGrille(*etatJeu);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -160,3 +171,26 @@ int verifierVictoire(struct EtatJeu etatJeu) {
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void afficherVictoire(int gagnant) {
|
||||||
|
char message[50];
|
||||||
|
sprintf(message, "Le Joueur %d a gagné !", gagnant);
|
||||||
|
|
||||||
|
/* Rectangle blanc pour le message */
|
||||||
|
ChoisirCouleurDessin(CouleurParNom("white"));
|
||||||
|
RemplirRectangle(200, 200, 400, 150);
|
||||||
|
|
||||||
|
/* Bordure du rectangle */
|
||||||
|
ChoisirCouleurDessin(CouleurParNom("black"));
|
||||||
|
DessinerRectangle(200, 200, 400, 150);
|
||||||
|
|
||||||
|
/* Message de victoire */
|
||||||
|
ChoisirCouleurDessin(gagnant == 1 ? CouleurParNom("blue") : CouleurParNom("red"));
|
||||||
|
EcrireTexte(250, 250, message, 2);
|
||||||
|
|
||||||
|
/* Instructions */
|
||||||
|
ChoisirCouleurDessin(CouleurParNom("black"));
|
||||||
|
EcrireTexte(220, 300, "Cliquez pour revenir au menu", 1);
|
||||||
|
|
||||||
|
printf("Partie terminée ! Le joueur %d a gagné !\n", gagnant);
|
||||||
|
}
|
||||||
|
|||||||
1
jeu.h
1
jeu.h
@@ -19,5 +19,6 @@ void gererClicSouris(struct EtatJeu *etatJeu);
|
|||||||
void dessinerGrille(struct EtatJeu etatJeu);
|
void dessinerGrille(struct EtatJeu etatJeu);
|
||||||
void DessinerCercle(int x, int y, int rayon);
|
void DessinerCercle(int x, int y, int rayon);
|
||||||
int verifierVictoire(struct EtatJeu etatJeu);
|
int verifierVictoire(struct EtatJeu etatJeu);
|
||||||
|
void afficherVictoire(int gagnant);
|
||||||
|
|
||||||
#endif /* JEU_H */
|
#endif /* JEU_H */
|
||||||
46
main.c
46
main.c
@@ -8,12 +8,14 @@ void menuPrincipale() {
|
|||||||
int tailleGrille = 3;
|
int tailleGrille = 3;
|
||||||
int continuer = 1;
|
int continuer = 1;
|
||||||
char tailleStr[4];
|
char tailleStr[4];
|
||||||
|
int besoinRedessiner = 1;
|
||||||
|
|
||||||
InitialiserGraphique();
|
InitialiserGraphique();
|
||||||
CreerFenetre(100, 100, 800, 600);
|
CreerFenetre(100, 100, 800, 600);
|
||||||
ChoisirTitreFenetre("Blocus");
|
ChoisirTitreFenetre("Blocus");
|
||||||
|
|
||||||
while (continuer) {
|
while (continuer) {
|
||||||
|
if (besoinRedessiner) {
|
||||||
EffacerEcran(CouleurParNom("white"));
|
EffacerEcran(CouleurParNom("white"));
|
||||||
ChoisirCouleurDessin(CouleurParNom("black"));
|
ChoisirCouleurDessin(CouleurParNom("black"));
|
||||||
EcrireTexte(300, 50, "BLOCUS", 2);
|
EcrireTexte(300, 50, "BLOCUS", 2);
|
||||||
@@ -36,64 +38,56 @@ void menuPrincipale() {
|
|||||||
ChoisirCouleurDessin(CouleurParNom("white"));
|
ChoisirCouleurDessin(CouleurParNom("white"));
|
||||||
EcrireTexte(320, 335, "Quitter", 1);
|
EcrireTexte(320, 335, "Quitter", 1);
|
||||||
|
|
||||||
|
besoinRedessiner = 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (SourisCliquee()) {
|
if (SourisCliquee()) {
|
||||||
int mouseX = _X;
|
int mouseX = _X;
|
||||||
int mouseY = _Y;
|
int mouseY = _Y;
|
||||||
printf("Menu click at: (%d, %d)\n", mouseX, mouseY);
|
printf("Clic détecté dans le menu à : (%d, %d)\n", mouseX, mouseY);
|
||||||
|
|
||||||
if (mouseX >= 500 && mouseX <= 530 && mouseY >= 110 && mouseY <= 140) {
|
if (mouseX >= 500 && mouseX <= 530 && mouseY >= 110 && mouseY <= 140) {
|
||||||
if (tailleGrille < 9) {
|
if (tailleGrille < 9) {
|
||||||
tailleGrille++;
|
tailleGrille++;
|
||||||
|
besoinRedessiner = 1;
|
||||||
}
|
}
|
||||||
} else if (mouseX >= 540 && mouseX <= 570 && mouseY >= 110 && mouseY <= 140) {
|
} else if (mouseX >= 540 && mouseX <= 570 && mouseY >= 110 && mouseY <= 140) {
|
||||||
if (tailleGrille > 3) {
|
if (tailleGrille > 3) {
|
||||||
tailleGrille--;
|
tailleGrille--;
|
||||||
|
besoinRedessiner = 1;
|
||||||
}
|
}
|
||||||
} else if (mouseX >= 250 && mouseX <= 550) {
|
} else if (mouseX >= 250 && mouseX <= 550) {
|
||||||
struct EtatJeu etatJeu;
|
struct EtatJeu etatJeu;
|
||||||
if (mouseY >= 180 && mouseY <= 230) {
|
if (mouseY >= 180 && mouseY <= 230 || mouseY >= 250 && mouseY <= 300) {
|
||||||
etatJeu = initialiserJeu(tailleGrille, 1);
|
int mode = (mouseY >= 180 && mouseY <= 230) ? 1 : 2;
|
||||||
|
etatJeu = initialiserJeu(tailleGrille, mode);
|
||||||
EffacerEcran(CouleurParNom("white"));
|
EffacerEcran(CouleurParNom("white"));
|
||||||
dessinerGrille(etatJeu);
|
dessinerGrille(etatJeu);
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
if (SourisCliquee()) {
|
if (SourisCliquee()) {
|
||||||
printf("Grid click detected at: (%d, %d)\n", _X, _Y);
|
printf("Clic détecté sur la grille à : (%d, %d)\n", _X, _Y);
|
||||||
gererClicSouris(&etatJeu);
|
gererClicSouris(&etatJeu);
|
||||||
|
|
||||||
int gagnant = verifierVictoire(etatJeu);
|
int gagnant = verifierVictoire(etatJeu);
|
||||||
if (gagnant != 0) {
|
if (gagnant != 0) {
|
||||||
printf("Le joueur %d a gagné !\n", gagnant);
|
afficherVictoire(gagnant);
|
||||||
|
printf("En attente d'un clic pour retourner au menu...\n");
|
||||||
|
while (!SourisCliquee()) {
|
||||||
|
usleep(100000);
|
||||||
|
}
|
||||||
|
besoinRedessiner = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
usleep(10000);
|
usleep(20000);
|
||||||
}
|
|
||||||
} else if (mouseY >= 250 && mouseY <= 300) {
|
|
||||||
etatJeu = initialiserJeu(tailleGrille, 2);
|
|
||||||
EffacerEcran(CouleurParNom("white"));
|
|
||||||
dessinerGrille(etatJeu);
|
|
||||||
|
|
||||||
while (1) {
|
|
||||||
if (SourisCliquee()) {
|
|
||||||
printf("Grid click detected at: (%d, %d)\n", _X, _Y);
|
|
||||||
gererClicSouris(&etatJeu);
|
|
||||||
|
|
||||||
int gagnant = verifierVictoire(etatJeu);
|
|
||||||
if (gagnant != 0) {
|
|
||||||
printf("Le joueur %d a gagné !\n", gagnant);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
usleep(10000);
|
|
||||||
}
|
}
|
||||||
} else if (mouseY >= 320 && mouseY <= 370) {
|
} else if (mouseY >= 320 && mouseY <= 370) {
|
||||||
continuer = 0;
|
continuer = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
usleep(20000);
|
||||||
usleep(10000);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
FermerGraphique();
|
FermerGraphique();
|
||||||
|
|||||||
Reference in New Issue
Block a user