Se réveler JoueurVirtuel

This commit is contained in:
Paul Gross
2020-05-14 10:15:16 +02:00
parent f0749eb6db
commit 3dacaac186
13 changed files with 168 additions and 32 deletions

View File

@@ -9,6 +9,6 @@ public enum Contexte {
ACTIVER_EFFET_LIEU,
EFFET_BOB,
LANCER_DES_4,
LANCER_DES_6, CHOISIR_VISION
LANCER_DES_6, CHOISIR_VISION, CHOISIR_ACTION
}

View File

@@ -16,6 +16,7 @@ import carte.CartePiochable.Type;
import carte.CarteVision;
import database.RessourceLoader;
import effet.Effet;
import effet.action.Action;
import ihm.controller.PlateauController;
import javafx.application.Platform;
@@ -49,10 +50,6 @@ public class GestionnaireJeu {
public void lancerPartie() {
plateau.start();
}
public Effet choisirEffet(Joueur joueur, Effet[] effets) {
return effets[0];
}
public void deplacer(Joueur currentJoueur) {
@@ -117,13 +114,36 @@ public class GestionnaireJeu {
return choisirEquipementVole(joueur, (List<CarteEquipement>) list);
}else if(cls == Joueur.class) {
return choisirJoueur(joueur, (List<Joueur>) list, Contexte.CHOISIR_VISION);
}else if(cls == Action.class) {
return choisirAction(joueur, (List<Action>) list, Contexte.CHOISIR_ACTION);
}
return list.get(0);
}
@SuppressWarnings("unchecked")
public Object choisir(Joueur joueur, List<?> list, Contexte c) {
return choisirJoueur(joueur, (List<Joueur>) list, c);
private Action choisirAction(Joueur joueur, List<Action> list, Contexte choisirAction) {
Platform.runLater(() -> {
pc.afficherChoisirAction(joueur,list);
});
this.waitPlateau();
final FutureTask<Action> query = new FutureTask<Action>(new Callable<Action>() {
@Override
public Action call() throws Exception {
return pc.getChoixAction(joueur);
}
});
Platform.runLater(query);
try {
return query.get();
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
}
return null;
}
public CarteEquipement choisirEquipementVole(Joueur joueur, List<CarteEquipement> lce) {
@@ -340,9 +360,14 @@ public class GestionnaireJeu {
try {
pc.afficherVision(j2, carteVision);
} catch (IOException e) {
e.printStackTrace();
}
});
waitPlateau();
}
public void reveler(Joueur joueur) {
Platform.runLater(() -> {
pc.revealJoueur(joueur);
});
}
}

View File

@@ -207,7 +207,10 @@ public class Joueur {
public String getNom() {
return this.nom;
}
public void reveal() {
GestionnaireJeu gj = GestionnaireJeu.getGestionnaireJeu();
gj.reveler(this);
this.revele = true;
}

View File

@@ -448,9 +448,6 @@ public class Plateau extends Thread{
return (Joueur) gj.choisir(joueur, joueurs, Joueur.class);
}
public Effet choisirEffet(Joueur joueur, Effet[] effets) {
return gj.choisirEffet(joueur,effets);
}
public Joueur choisirParmisTous(Joueur joueur) {
List<Joueur> joueurs = new ArrayList<Joueur>();