Compare commits
7 Commits
b01bad0460
...
Line_Anima
| Author | SHA1 | Date | |
|---|---|---|---|
| c096758b32 | |||
| ff992b1d50 | |||
| 570adb8ad3 | |||
| a96ac46cc4 | |||
| 15657fc319 | |||
| 001aa3a098 | |||
| a0ee2c5f56 |
@@ -63,6 +63,13 @@ public class Cercle extends ObjetGraphique{ // il s'agit plutôt d'arcs de cercl
|
||||
return rayon;
|
||||
}
|
||||
|
||||
//-------------------------------------------------------------------------
|
||||
// Méthode qui retourne la position du cercle en y (utile pour la classe qui vérifiera si la ligne passe dans le cercle)
|
||||
//-------------------------------------------------------------------------
|
||||
@Override
|
||||
public double getY(){
|
||||
return y;
|
||||
}
|
||||
|
||||
//-------------------------------------------------------------------------
|
||||
// Méthode qui note que up a été appuyée
|
||||
|
||||
@@ -134,17 +134,28 @@ public class Jeu implements KeyListener, ActionListener{
|
||||
|
||||
// A FAIRE :
|
||||
// donner la couleur des 2 demi-cercles, par exemple : demiCerleArriere.setCouleur(new Color(0.8f,0.0f,0.0f));
|
||||
demiCercleArriere.setCouleur(new Color(220, 20, 60));
|
||||
demiCercleAvant.setCouleur(new Color(220, 20, 60));
|
||||
demiCercleArriere.setCouleur(new Color(26, 95, 161));
|
||||
demiCercleAvant.setCouleur(new Color(26, 95, 161));
|
||||
}
|
||||
|
||||
|
||||
//-------------------------------------------------------------------------
|
||||
//------------------------------------------------------------------------------------------------
|
||||
// Méthode appelée lorsqu'un événement timer se produit
|
||||
//-------------------------------------------------------------------------
|
||||
// -> C'est ici que la loqique et l'animation du jeu sont traitées
|
||||
// -> C'est ici que la vérification de la collision entre la ligne et le cercle doit être faite
|
||||
//------------------------------------------------------------------------------------------------
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
|
||||
this.ecran.traiterBoucleAnimation();
|
||||
boolean verification = this.laLigne.estDansCercle(this.demiCercleAvant);
|
||||
/*if(verification == false){
|
||||
//horloge.stop();
|
||||
System.out.println("Perdu ! Votre score est de : " + this.score);
|
||||
}
|
||||
else{
|
||||
this.score += 1;
|
||||
System.out.println("Score : " + this.score);
|
||||
}*/
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -35,7 +35,7 @@ public class Ligne extends ObjetGraphique{// Hérite de la classe ObjetGraphique
|
||||
//-------------------------------------------------------------------------
|
||||
public Ligne(){
|
||||
// Valeurs initiales pour la position de la Ligne
|
||||
double x = 0;
|
||||
double x = 800;
|
||||
double y = 200;
|
||||
double dx,dy;
|
||||
|
||||
@@ -91,6 +91,66 @@ public class Ligne extends ObjetGraphique{// Hérite de la classe ObjetGraphique
|
||||
// Principe :
|
||||
// on parcourt tous les segments et on décale chacun de 10 pixels (par exemple)
|
||||
// vers la gauche
|
||||
for(Segment s: this.listeSegments){
|
||||
s.x -= 5;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------------------
|
||||
// Méthode permettant de vérifier si la ligne est à l'intérieur du cercle
|
||||
// Principe: On a le rayon du cercle qui ne varie pas
|
||||
// On parcourt tous les points du segment courant
|
||||
// Et on calcule la distance entre chacun de ces points et le centre du cercle
|
||||
// Si la distance est supérieure au rayon du cercle, alors le point n'est pas dans le cercle
|
||||
// Sinon le segment courant est dans le cercle
|
||||
// Remarque: On a définit la position du cercle grâce à son centre
|
||||
// Autrement dit, les coordonnées du centre du cercle sont la position du cercle
|
||||
// Raison pour laquelle au début la ligne est toujours dans le cercle
|
||||
// Car yCercle = yLigne = 200 (Voir et lire le code attentivement) !!!!
|
||||
// Formule de la distance : d = sqrt( (x2-x1)^2 + (y2-y1)^2 )
|
||||
// !!! Attention: il faut vérifier si le segment courant existe avant de faire les calculs
|
||||
// Sinon l'écran rique de se figer à cause d'un nullPointerException
|
||||
//----------------------------------------------------------------------------------------
|
||||
public boolean estDansCercle(Cercle c){
|
||||
boolean dansCercle = false;
|
||||
// Si aucun segment courant n'a encore été déterminé (peut arriver
|
||||
// avant le premier paint), on tente de le retrouver ici pour
|
||||
// éviter un NullPointerException qui fige l'EDT.
|
||||
if (this.SegCourant == null) {
|
||||
for (Segment s : this.listeSegments) {
|
||||
if ((s.x <= xCercle) && ((s.x + s.xLong) >= xCercle)) {
|
||||
this.SegCourant = s;
|
||||
// On peut s'arrêter dès qu'on a trouvé le segment courant
|
||||
break;
|
||||
}
|
||||
}
|
||||
// fallback : prendre le premier segment si aucune correspondance
|
||||
if (this.SegCourant == null && !this.listeSegments.isEmpty()) {
|
||||
this.SegCourant = this.listeSegments.get(0);
|
||||
}
|
||||
}
|
||||
|
||||
// Si toujours null (liste vide), on ne peut pas vérifier
|
||||
if (this.SegCourant == null) {
|
||||
return false;
|
||||
}
|
||||
double yCercle = c.getY();
|
||||
for(int i = 0; i <= 50; i++){
|
||||
double xPoint = this.SegCourant.x + (i/50.0)*this.SegCourant.xLong;
|
||||
double yPoint = this.SegCourant.y + (i/50.0)*this.SegCourant.yLong;
|
||||
double distance = Math.sqrt(Math.pow((xCercle - xPoint), 2) + Math.pow((yCercle - yPoint), 2));
|
||||
if(distance <= c.getRayon()){
|
||||
// Le point i du segment courant est dans le cercle, on peut continuer à vérifier les autres points du segment
|
||||
this.SegCourant.setCouleur(Color.GREEN);
|
||||
dansCercle = true;
|
||||
}else{
|
||||
// On peut s'arrêter dès qu'on trouve un point hors du cercle, car le segment courant n'est plus dans le cercle
|
||||
this.SegCourant.setCouleur(Color.RED);
|
||||
dansCercle = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return dansCercle;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -51,8 +51,7 @@ public class Segment extends ObjetGraphique { // Hérite de la classe ObjetGraph
|
||||
//-------------------------------------------------------------------------
|
||||
@Override
|
||||
void Animer() {
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user