fait enum contexte et changements a tester sur IA
This commit is contained in:
parent
641d298bd3
commit
8042514def
10
src/main/Contexte.java
Normal file
10
src/main/Contexte.java
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
package main;
|
||||||
|
|
||||||
|
public enum Contexte {
|
||||||
|
|
||||||
|
ATTAQUER,
|
||||||
|
VOLER_EQUIP,
|
||||||
|
EFFET_NEGATIF_SUR_AUTRES,
|
||||||
|
EFFET_POSITIF_SUR_AUTRES
|
||||||
|
|
||||||
|
}
|
@ -68,6 +68,20 @@ public class ControleurIA {
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static List<Joueur> getAmisJoueurs(JoueurVirtuel jIA, List<Joueur> joueursLieu) {
|
||||||
|
List<Joueur> res = new ArrayList<>();
|
||||||
|
Equipe equipejIA = jIA.getEquipe();
|
||||||
|
if (equipejIA == CartePersonnage.Equipe.NEUTRE)
|
||||||
|
res = joueursLieu;
|
||||||
|
else {
|
||||||
|
for (Joueur j : joueursLieu) {
|
||||||
|
if (equipejIA.equals(j.getEquipe()))
|
||||||
|
res.add(j);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
// loup-garou : si attaquee par joueur pas du meme camps 60%? devoilement
|
// loup-garou : si attaquee par joueur pas du meme camps 60%? devoilement
|
||||||
public boolean devoilerIALoupGarou(JoueurVirtuel jIA, Joueur jAttaquant) {
|
public boolean devoilerIALoupGarou(JoueurVirtuel jIA, Joueur jAttaquant) {
|
||||||
Equipe equipejIA = jIA.getEquipe();
|
Equipe equipejIA = jIA.getEquipe();
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
package main;
|
package main;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -6,7 +7,6 @@ import carte.Equipement;
|
|||||||
import carte.EquipementStat;
|
import carte.EquipementStat;
|
||||||
import effet.Effet;
|
import effet.Effet;
|
||||||
|
|
||||||
|
|
||||||
public class JoueurVirtuel extends Joueur {
|
public class JoueurVirtuel extends Joueur {
|
||||||
|
|
||||||
private int nvDifficulte = 1; // possibilite de 1, 2 ou 3
|
private int nvDifficulte = 1; // possibilite de 1, 2 ou 3
|
||||||
@ -36,12 +36,74 @@ public class JoueurVirtuel extends Joueur {
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
//on choisit les joueurs avec les moins de hp, on ne distingue pas cependant d'amie ou ennemi
|
public Joueur choisirJoueur(List<Joueur> joueurs, Contexte c) {
|
||||||
public Joueur choisirJoueur(List<Joueur> joueurs) {
|
Joueur res;
|
||||||
Joueur res = joueurs.get(0);
|
switch (c) {
|
||||||
for(int i=1; i<joueurs.size();i++) {
|
case ATTAQUER:
|
||||||
if(res.getStat("HP")>joueurs.get(i).getStat("HP"))
|
res = choisirJoueurEnnemi(joueurs);
|
||||||
res = joueurs.get(i);
|
break;
|
||||||
|
case VOLER_EQUIP:
|
||||||
|
res = choisirJoueurAVoler(joueurs);
|
||||||
|
break;
|
||||||
|
case EFFET_NEGATIF_SUR_AUTRES:
|
||||||
|
res = choisirJoueurEnnemi(joueurs);
|
||||||
|
break;
|
||||||
|
case EFFET_POSITIF_SUR_AUTRES:
|
||||||
|
res = choisirJoueurAmi(joueurs);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
res = null; // faire exception?
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
// on choisit les joueurs avec les moins de hp, on met en priorite les ennemis
|
||||||
|
public Joueur choisirJoueurEnnemi(List<Joueur> joueurs) {
|
||||||
|
List<Joueur> resliste;
|
||||||
|
List<Joueur> ennemis = ControleurIA.getEnnemisJoueurs(this, joueurs);
|
||||||
|
if (ennemis.size() > 0)
|
||||||
|
resliste = ennemis;
|
||||||
|
else
|
||||||
|
resliste = joueurs;
|
||||||
|
Joueur res = resliste.get(0);
|
||||||
|
for (int i = 1; i < resliste.size(); i++) {
|
||||||
|
if (res.getStat("HP") > resliste.get(i).getStat("HP"))
|
||||||
|
res = resliste.get(i);
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
// return joueurs.get((int)Math.floor(Math.random() * joueurs.size()));
|
||||||
|
}
|
||||||
|
|
||||||
|
// on choisit les joueurs avec le plus d'equipements, on met en priorite les
|
||||||
|
// ennemis
|
||||||
|
public Joueur choisirJoueurAVoler(List<Joueur> joueurs) {
|
||||||
|
List<Joueur> resliste;
|
||||||
|
List<Joueur> ennemis = ControleurIA.getEnnemisJoueurs(this, joueurs);
|
||||||
|
if (ennemis.size() > 0)
|
||||||
|
resliste = ennemis;
|
||||||
|
else
|
||||||
|
resliste = joueurs;
|
||||||
|
Joueur res = resliste.get(0);
|
||||||
|
for (int i = 1; i < resliste.size(); i++) {
|
||||||
|
if (res.getStat("nb_equipements") > resliste.get(i).getStat("nb_equipements"))
|
||||||
|
res = resliste.get(i);
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
// on choisit les joueurs avec les moins de hp, on met en priorite les amis (ex:
|
||||||
|
// pour les soigner?)
|
||||||
|
public Joueur choisirJoueurAmi(List<Joueur> joueurs) {
|
||||||
|
List<Joueur> resliste;
|
||||||
|
List<Joueur> ennemis = ControleurIA.getAmisJoueurs(this, joueurs);
|
||||||
|
if (ennemis.size() > 0)
|
||||||
|
resliste = ennemis;
|
||||||
|
else
|
||||||
|
resliste = joueurs;
|
||||||
|
Joueur res = resliste.get(0);
|
||||||
|
for (int i = 1; i < resliste.size(); i++) {
|
||||||
|
if (res.getStat("HP") > resliste.get(i).getStat("HP"))
|
||||||
|
res = resliste.get(i);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
// return joueurs.get((int)Math.floor(Math.random() * joueurs.size()));
|
// return joueurs.get((int)Math.floor(Math.random() * joueurs.size()));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user