diff --git a/SAE_semestre1/fichier.h/main.h b/SAE_semestre1/fichier.h/main.h index 39d1c80..0c85dc3 100755 --- a/SAE_semestre1/fichier.h/main.h +++ b/SAE_semestre1/fichier.h/main.h @@ -1,6 +1,7 @@ #ifndef MAIN_H #define MAIN_H - int main(void); +int jeu(void); +int main(void); #endif \ No newline at end of file diff --git a/SAE_semestre1/fichier.h/menu.h b/SAE_semestre1/fichier.h/menu.h index 132380e..716d75b 100755 --- a/SAE_semestre1/fichier.h/menu.h +++ b/SAE_semestre1/fichier.h/menu.h @@ -1,6 +1,10 @@ #ifndef MENU_H #define MENU_H -void menu(void); +typedef struct { + int x, y, L, H; +} zone; +int check_zone(zone z, int x, int y); +void afficher_menu(zone jouer, zone quitter, int *jeu); #endif \ No newline at end of file diff --git a/SAE_semestre1/fichier.h/serpent.h b/SAE_semestre1/fichier.h/serpent.h index 42094a5..a63307d 100755 --- a/SAE_semestre1/fichier.h/serpent.h +++ b/SAE_semestre1/fichier.h/serpent.h @@ -4,5 +4,5 @@ void Serpent(int pos_x[], int pos_y[], int old_x[], int old_y[], int *segment, int murx[], int mury[], int *go_on, int *direction); void Collision_Serpent(int pos_x[], int pos_y[], int segment, int murx[], int mury[], int *go_on); void Update_Serpent(int pos_x[], int pos_y[], int segment, int old_x[], int old_y[], int*); -void Controle(int *direction, int last_direction, int *go_on); +void Controle(int *direction, int last_direction, int *go_on, int *pause); #endif diff --git a/SAE_semestre1/img/tete_down.png b/SAE_semestre1/img/tete_down.png new file mode 100644 index 0000000..91f5e1d Binary files /dev/null and b/SAE_semestre1/img/tete_down.png differ diff --git a/SAE_semestre1/img/tete_left.png b/SAE_semestre1/img/tete_left.png new file mode 100644 index 0000000..ead6573 Binary files /dev/null and b/SAE_semestre1/img/tete_left.png differ diff --git a/SAE_semestre1/img/tete_right.png b/SAE_semestre1/img/tete_right.png new file mode 100644 index 0000000..90f935e Binary files /dev/null and b/SAE_semestre1/img/tete_right.png differ diff --git a/SAE_semestre1/img/tete_up.png b/SAE_semestre1/img/tete_up.png new file mode 100644 index 0000000..e93e56d Binary files /dev/null and b/SAE_semestre1/img/tete_up.png differ diff --git a/SAE_semestre1/src/main.c b/SAE_semestre1/src/main.c index 7defba4..9dc3428 100644 --- a/SAE_semestre1/src/main.c +++ b/SAE_semestre1/src/main.c @@ -5,10 +5,12 @@ #include "../fichier.h/Oeuf.h" #include "../fichier.h/time.h" #include "../fichier.h/main.h" +#include "../fichier.h/menu.h" -#define CYCLE 10000L +#define CYCLE 100000L -int main(void){ +int lancer_jeu(){ + int pause = 1; int segment = 10; int go_on = 1; int direction = 4; @@ -34,23 +36,35 @@ int main(void){ unsigned long int *pointeur_suivant = &suivant; int *pointeur_seconde_actuel = &seconde_actuel; int *pointeur_old_seconde = &old_seconde; - InitialiserGraphique(); - CreerFenetre(350,100,1200,900); - EffacerEcran(CouleurParComposante(0,0,0)); + int *pointeur_pause = &pause; suivant = Microsecondes()+CYCLE; old_seconde=(suivant/1000000)%10; DessinerScene(murx, mury, minute, seconde ,timer); InitialiserOeufs(oeufx, oeufy, segment); Serpent(pos_x, pos_y, old_x, old_y, pointeur_segment, murx, mury, pointeur_go_on, pointeur_direction); while(go_on){ + Controle(pointeur_direction, 0, pointeur_go_on, pointeur_pause); + if(pause == 1){ Timer( pointeur_minute, pointeur_seconde, pointeur_suivant, pointeur_seconde_actuel, pointeur_old_seconde, timer); - Score(segment); - Controle(pointeur_direction, 0, pointeur_go_on); Update_Serpent(pos_x, pos_y, segment, old_x, old_y, pointeur_direction); Collision_Serpent(pos_x, pos_y, segment, murx, mury, pointeur_go_on); + Score(segment); usleep(100000); Oeuf(pos_x, pos_y, oeufx, oeufy, pointeur_segment); } + } +} +int main(void){ + int choix = 0; + InitialiserGraphique(); + CreerFenetre(350,100,1200,900); + EffacerEcran(CouleurParComposante(0,0,0)); + afficher_menu(&choix); + + while( choix == 1){ + lancer_jeu(); + } FermerGraphique(); return EXIT_SUCCESS; } + diff --git a/SAE_semestre1/src/menu.c b/SAE_semestre1/src/menu.c index 25d967b..5c7a832 100755 --- a/SAE_semestre1/src/menu.c +++ b/SAE_semestre1/src/menu.c @@ -1,25 +1,24 @@ #include #include +#include #include "../fichier.h/menu.h" - -int MenuDebut(){ - InitialiserGraphique(); - EcrireTexte(1000,760,"Score", 2); +int check_zone(zone z, int x, int y) { + return x >= z.x && x <= z.x + z.L && y >= z.y && y <= z.y + z.H; } -int menu(){ - while(menu){ - while(ToucheEnAttente()){ - t = Touche(); - switch(t3){ - case XK_q : - FermerGraphique(); - return EXIT_SUCCESS; - return; - case XK_Right : - menu = 0; - return + +void afficher_menu(zone jouer, zone quitter, int *choix) { + ChargerImageFond("../img/Menu.png"); + while(1){ + SourisPosition(); + + if(SourisCliquee()){ + int x = _X; + int y = _Y; + if (check_zone(jouer, _X, _Y)){ + *choix = 1; + return; } - } + } } -} \ No newline at end of file +} diff --git a/SAE_semestre1/src/serpent.c b/SAE_semestre1/src/serpent.c index 117bf06..d2f87d5 100755 --- a/SAE_semestre1/src/serpent.c +++ b/SAE_semestre1/src/serpent.c @@ -57,7 +57,7 @@ void Collision_Serpent(int pos_x[], int pos_y[], int segment, int murx[], int mu } } -void Controle(int *direction, int last_direction, int *go_on) { +void Controle(int *direction, int last_direction, int *go_on, int *pause) { int t; while(ToucheEnAttente()) { t = Touche(); @@ -86,8 +86,13 @@ void Controle(int *direction, int last_direction, int *go_on) { *direction = 0; *go_on = 0; return; - case XK_p: - *direction = 0; + case XK_space: + if (*pause == 0 ){ + *pause == 1; + }else{ + *pause = 0; + ChargerImage("../img/PAUSE.png", 400,200,0,0,350,300); + } } } } diff --git a/SAE_semestre1/src/time.c b/SAE_semestre1/src/time.c index 1a6b578..aa6fb39 100755 --- a/SAE_semestre1/src/time.c +++ b/SAE_semestre1/src/time.c @@ -4,7 +4,7 @@ #include "../fichier.h/time.h" #include "../fichier.h/main.h" #include "../fichier.h/serpent.h" -#define CYCLE 10000L +#define CYCLE 100000L void Score(int segment){ int nombre;