Ajout de fonctionnalités main, pioche
This commit is contained in:
parent
1d1519bb17
commit
7d1090bf8b
@ -3,14 +3,11 @@ package carte;
|
|||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
import main.Type;
|
import main.Type;
|
||||||
|
|
||||||
public class CartePiochable<T> extends CarteCondition implements Type{
|
public class CartePiochable<T extends Type> extends CarteCondition{
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public void utiliser(Joueur j) {
|
public void utiliser(Joueur j) {
|
||||||
super.utiliser(j);
|
super.utiliser(j);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
16
src/condition/WinConditionHunter.java
Normal file
16
src/condition/WinConditionHunter.java
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
package condition;
|
||||||
|
|
||||||
|
import main.Joueur;
|
||||||
|
import main.Plateau;
|
||||||
|
|
||||||
|
public class WinConditionHunter extends Condition{
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isTrue(Joueur j)
|
||||||
|
{
|
||||||
|
int nbShadow = j.getPlateau().getStat(Plateau.NB_SHADOWS);
|
||||||
|
Condition winCondition = new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_SHADOW, nbShadow, ConditionStatistiques.MORE);
|
||||||
|
return winCondition.isTrue(j);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
16
src/condition/WinConditionShadow.java
Normal file
16
src/condition/WinConditionShadow.java
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
package condition;
|
||||||
|
|
||||||
|
import main.Joueur;
|
||||||
|
import main.Plateau;
|
||||||
|
|
||||||
|
public class WinConditionShadow extends Condition{
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isTrue(Joueur j)
|
||||||
|
{
|
||||||
|
int nbHunter = j.getPlateau().getStat(Plateau.NB_HUNTERS);
|
||||||
|
Condition winCondition = new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_HUNTER, nbHunter, ConditionStatistiques.MORE);
|
||||||
|
return winCondition.isTrue(j);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,7 +0,0 @@
|
|||||||
package main;
|
|
||||||
|
|
||||||
import carte.Carte;
|
|
||||||
|
|
||||||
public class CartePiochable<Type> extends Carte<Type> {
|
|
||||||
|
|
||||||
}
|
|
@ -3,7 +3,6 @@ import java.util.HashMap;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import carte.CarteLieu;
|
|
||||||
import effet.Effet;
|
import effet.Effet;
|
||||||
|
|
||||||
|
|
||||||
@ -18,10 +17,11 @@ public class Joueur {
|
|||||||
// map keys
|
// map keys
|
||||||
public static final String PLAYER_HP = "hp";
|
public static final String PLAYER_HP = "hp";
|
||||||
public static final String PLAYER_TURN = "turn";
|
public static final String PLAYER_TURN = "turn";
|
||||||
public static final String PLYAYER_DAMAGE = "damage";
|
public static final String PLAYER_DAMAGE = "damage";
|
||||||
public static final String PLAYER_RESISTANCE = "resistance";
|
public static final String PLAYER_RESISTANCE = "resistance";
|
||||||
public static final String PLAYER_REVEAL = "reveal";
|
public static final String PLAYER_REVEAL = "reveal";
|
||||||
public static final String PLAYER_IMMUNITY = "immunity";
|
public static final String PLAYER_IMMUNITY = "immunity";
|
||||||
|
public static final String PLAYER_NB_EQUIPEMENTS = "nb_equipements";
|
||||||
|
|
||||||
private Map<String, Integer> stats;
|
private Map<String, Integer> stats;
|
||||||
|
|
||||||
@ -67,7 +67,7 @@ public class Joueur {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Equipement> getEquipements() {
|
public Equipement[] getEquipements() {
|
||||||
// TODO Auto-generated method stub
|
// TODO Auto-generated method stub
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,22 @@
|
|||||||
package main;
|
package main;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.Stack;
|
||||||
|
|
||||||
public class Pioche<Carte> {
|
import carte.CartePiochable;
|
||||||
private List<CartePiochable> cartesPiochables;
|
|
||||||
|
public class Pioche<T extends Type> {
|
||||||
|
|
||||||
public CartePiochable piocher() {
|
private Stack<CartePiochable<T>> cartesPiochables;
|
||||||
|
|
||||||
|
|
||||||
|
public void melanger()
|
||||||
|
{
|
||||||
Collections.shuffle(cartesPiochables);
|
Collections.shuffle(cartesPiochables);
|
||||||
return cartesPiochables.get(0);
|
}
|
||||||
|
|
||||||
|
public CartePiochable<?> piocher() {
|
||||||
|
|
||||||
|
return cartesPiochables.pop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
package main;
|
package main;
|
||||||
|
|
||||||
public class TypeTenebre {
|
public class TypeTenebre implements Type{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -12,8 +12,8 @@ import main.Plateau;
|
|||||||
|
|
||||||
public class Allie extends Unique{
|
public class Allie extends Unique{
|
||||||
|
|
||||||
public Allie(String nom, int hp, Joueur joueur,boolean capaciteUsed) {
|
public Allie(String nom, int hp, Joueur joueur) {
|
||||||
super(nom, hp, joueur, capaciteUsed);
|
super(nom, hp, joueur);
|
||||||
|
|
||||||
Action action = new ActionAltererStatistiquesJoueur("HP",this.getPv(),false);
|
Action action = new ActionAltererStatistiquesJoueur("HP",this.getPv(),false);
|
||||||
Effet effet = new EffetSelf(action);
|
Effet effet = new EffetSelf(action);
|
||||||
|
@ -1,14 +1,21 @@
|
|||||||
package personnage;
|
package personnage;
|
||||||
|
|
||||||
import condition.Condition;
|
import condition.Condition;
|
||||||
|
import condition.ConditionStatistiques;
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
|
|
||||||
public class Bob extends CartePersonnage{
|
public class Bob extends CartePersonnage{
|
||||||
|
|
||||||
public Bob(String nom, int hp, Joueur joueur, Condition condition,boolean capaciteUsed) {
|
public Bob(String nom, int hp, Joueur joueur) {
|
||||||
super(nom, hp, joueur, condition);
|
super(nom, hp, joueur);
|
||||||
|
Condition condition = new ConditionStatistiques(ConditionStatistiques.JOUEUR, Joueur.PLAYER_NB_EQUIPEMENTS, 5, ConditionStatistiques.MORE);
|
||||||
|
this.setCondition(condition);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void utiliser(Joueur j){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public void attaquer(Joueur j) {
|
public void attaquer(Joueur j) {
|
||||||
|
|
||||||
|
@ -1,19 +1,15 @@
|
|||||||
package personnage;
|
package personnage;
|
||||||
|
|
||||||
import condition.Condition;
|
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
|
|
||||||
public class Charles extends CartePersonnage{
|
public class Charles extends CartePersonnage{
|
||||||
//attributs
|
|
||||||
private boolean capaciteUsed;
|
|
||||||
|
|
||||||
//constructeur
|
//constructeur
|
||||||
public Charles(String nom, int hp, Joueur joueur,Condition condition,boolean capaciteUsed) {
|
public Charles(String nom, int hp, Joueur joueur) {
|
||||||
super(nom, hp, joueur, condition);
|
super(nom, hp, joueur);
|
||||||
this.capaciteUsed=capaciteUsed;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//méthode
|
//m<EFBFBD>thode
|
||||||
public void attaquer(Joueur j) {
|
public void attaquer(Joueur j) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ import condition.Condition;
|
|||||||
import condition.ConditionMultiple;
|
import condition.ConditionMultiple;
|
||||||
import condition.ConditionMultipleOR;
|
import condition.ConditionMultipleOR;
|
||||||
import condition.ConditionStatistiques;
|
import condition.ConditionStatistiques;
|
||||||
|
import condition.WinConditionHunter;
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
import main.Plateau;
|
import main.Plateau;
|
||||||
|
|
||||||
@ -22,7 +23,7 @@ public class Daniel extends CartePersonnage{
|
|||||||
,new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS, 1, ConditionStatistiques.LESS)
|
,new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS, 1, ConditionStatistiques.LESS)
|
||||||
)
|
)
|
||||||
// Shadows morts
|
// Shadows morts
|
||||||
,new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_SHADOW, nbShadow, ConditionStatistiques.MORE)
|
,new WinConditionHunter()
|
||||||
);
|
);
|
||||||
this.setCondition(winCondition);
|
this.setCondition(winCondition);
|
||||||
}
|
}
|
||||||
|
@ -1,18 +1,14 @@
|
|||||||
package personnage;
|
package personnage;
|
||||||
|
|
||||||
import condition.Condition;
|
import condition.WinConditionHunter;
|
||||||
import condition.ConditionStatistiques;
|
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
import main.Plateau;
|
|
||||||
|
|
||||||
public class Emi extends CartePersonnage{
|
public class Emi extends CartePersonnage{
|
||||||
//constructeur
|
//constructeur
|
||||||
public Emi(String nom, int hp, Joueur joueur) {
|
public Emi(String nom, int hp, Joueur joueur) {
|
||||||
super(nom, hp, joueur);
|
super(nom, hp, joueur);
|
||||||
|
|
||||||
int nbShadow = joueur.getPlateau().getStat(Plateau.NB_SHADOWS);
|
this.setCondition(new WinConditionHunter());
|
||||||
Condition winCondition = new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_SHADOW, nbShadow, ConditionStatistiques.MORE);
|
|
||||||
this.setCondition(winCondition);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//m<EFBFBD>thode
|
//m<EFBFBD>thode
|
||||||
|
@ -1,19 +1,14 @@
|
|||||||
package personnage;
|
package personnage;
|
||||||
|
|
||||||
import condition.Condition;
|
import condition.WinConditionHunter;
|
||||||
import condition.ConditionStatistiques;
|
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
import main.Plateau;
|
|
||||||
|
|
||||||
public class Franklin extends Unique{
|
public class Franklin extends Unique{
|
||||||
|
|
||||||
//constructeur
|
//constructeur
|
||||||
public Franklin(String nom, int hp, Joueur joueur) {
|
public Franklin(String nom, int hp, Joueur joueur) {
|
||||||
super(nom, hp, joueur);
|
super(nom, hp, joueur);
|
||||||
int nbShadow = joueur.getPlateau().getStat(Plateau.NB_SHADOWS);
|
this.setCondition(new WinConditionHunter());
|
||||||
Condition winCondition = new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_SHADOW, nbShadow, ConditionStatistiques.MORE);
|
|
||||||
this.setCondition(winCondition);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//m<EFBFBD>thode
|
//m<EFBFBD>thode
|
||||||
|
@ -1,20 +1,14 @@
|
|||||||
package personnage;
|
package personnage;
|
||||||
|
|
||||||
import condition.Condition;
|
import condition.WinConditionHunter;
|
||||||
import condition.ConditionStatistiques;
|
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
import main.Plateau;
|
|
||||||
|
|
||||||
public class Georges extends Unique{
|
public class Georges extends Unique{
|
||||||
|
|
||||||
//constructeur
|
//constructeur
|
||||||
public Georges(String nom, int hp, Joueur joueur) {
|
public Georges(String nom, int hp, Joueur joueur) {
|
||||||
super(nom, hp, joueur);
|
super(nom, hp, joueur);
|
||||||
|
this.setCondition(new WinConditionHunter());
|
||||||
int nbShadow = joueur.getPlateau().getStat(Plateau.NB_SHADOWS);
|
|
||||||
Condition winCondition = new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_SHADOW, nbShadow, ConditionStatistiques.MORE);
|
|
||||||
this.setCondition(winCondition);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//m<EFBFBD>thode
|
//m<EFBFBD>thode
|
||||||
|
@ -1,23 +1,14 @@
|
|||||||
package personnage;
|
package personnage;
|
||||||
|
|
||||||
import condition.Condition;
|
import condition.WinConditionShadow;
|
||||||
import condition.ConditionMultipleOR;
|
|
||||||
import condition.ConditionStatistiques;
|
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
import main.Plateau;
|
|
||||||
|
|
||||||
public class LoupGarou extends CartePersonnage {
|
public class LoupGarou extends CartePersonnage {
|
||||||
//constructeur
|
//constructeur
|
||||||
public LoupGarou(String nom, int hp, Joueur joueur) {
|
public LoupGarou(String nom, int hp, Joueur joueur) {
|
||||||
super(nom, hp, joueur);
|
super(nom, hp, joueur);
|
||||||
|
|
||||||
int nbHunter = joueur.getPlateau().getStat(Plateau.NB_HUNTERS);
|
this.setCondition(new WinConditionShadow());
|
||||||
Condition winCondition = new ConditionMultipleOR(
|
|
||||||
new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_HUNTER, nbHunter, ConditionStatistiques.MORE)
|
|
||||||
,
|
|
||||||
new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_NEUTRAL, 3, ConditionStatistiques.MORE)
|
|
||||||
);
|
|
||||||
this.setCondition(winCondition);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//m<EFBFBD>thodes
|
//m<EFBFBD>thodes
|
||||||
|
@ -1,24 +1,13 @@
|
|||||||
package personnage;
|
package personnage;
|
||||||
|
|
||||||
import condition.Condition;
|
import condition.WinConditionShadow;
|
||||||
import condition.ConditionMultipleOR;
|
|
||||||
import condition.ConditionStatistiques;
|
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
import main.Plateau;
|
|
||||||
|
|
||||||
public class Metamorphe extends CartePersonnage{
|
public class Metamorphe extends CartePersonnage{
|
||||||
|
|
||||||
public Metamorphe(String nom, int pv, Joueur joueur) {
|
public Metamorphe(String nom, int pv, Joueur joueur) {
|
||||||
super(nom, pv, joueur);
|
super(nom, pv, joueur);
|
||||||
|
this.setCondition(new WinConditionShadow());
|
||||||
|
|
||||||
int nbHunter = joueur.getPlateau().getStat(Plateau.NB_HUNTERS);
|
|
||||||
Condition winCondition = new ConditionMultipleOR(
|
|
||||||
new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_HUNTER, nbHunter, ConditionStatistiques.MORE)
|
|
||||||
,
|
|
||||||
new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_NEUTRAL, 3, ConditionStatistiques.MORE)
|
|
||||||
);
|
|
||||||
this.setCondition(winCondition);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,14 +1,12 @@
|
|||||||
package personnage;
|
package personnage;
|
||||||
|
|
||||||
import condition.Condition;
|
import condition.WinConditionShadow;
|
||||||
import condition.ConditionMultipleOR;
|
|
||||||
import condition.ConditionStatistiques;
|
|
||||||
import effet.Action;
|
import effet.Action;
|
||||||
import effet.ActionAltererStatistiquesJoueur;
|
import effet.ActionAltererStatistiquesJoueur;
|
||||||
import effet.Effet;
|
import effet.Effet;
|
||||||
import effet.EffetSelf;
|
import effet.EffetSelf;
|
||||||
import main.Joueur;
|
import main.Joueur;
|
||||||
import main.Plateau;
|
|
||||||
|
|
||||||
public class Vampire extends CartePersonnage{
|
public class Vampire extends CartePersonnage{
|
||||||
|
|
||||||
@ -18,14 +16,7 @@ public class Vampire extends CartePersonnage{
|
|||||||
Action action = new ActionAltererStatistiquesJoueur("HP",2,true);
|
Action action = new ActionAltererStatistiquesJoueur("HP",2,true);
|
||||||
Effet effet = new EffetSelf(action);
|
Effet effet = new EffetSelf(action);
|
||||||
this.setEffet(effet);
|
this.setEffet(effet);
|
||||||
|
this.setCondition(new WinConditionShadow());
|
||||||
int nbHunter = joueur.getPlateau().getStat(Plateau.NB_HUNTERS);
|
|
||||||
Condition winCondition = new ConditionMultipleOR(
|
|
||||||
new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_HUNTER, nbHunter, ConditionStatistiques.MORE)
|
|
||||||
,
|
|
||||||
new ConditionStatistiques(ConditionStatistiques.PLATEAU, Plateau.NB_MORTS_NEUTRAL, 3, ConditionStatistiques.MORE)
|
|
||||||
);
|
|
||||||
this.setCondition(winCondition);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void utiliser(Joueur j)
|
public void utiliser(Joueur j)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user