diff --git a/src/modele/calculs/Items.java b/src/modele/calculs/Items.java new file mode 100644 index 0000000..7cb34ca --- /dev/null +++ b/src/modele/calculs/Items.java @@ -0,0 +1,20 @@ +package modele.calculs; + +import modele.donnees.ElementDynamique; +import modele.donnees.Heros; + +public class Items extends RealisateurDeDeplacement { + public Items() { + } + + @Override + protected boolean realiserDeplacement() { + for (ElementDynamique e : lstEntitesDynamiques) + if(e instanceof modele.donnees.Items) { + modele.donnees.Items i = (modele.donnees.Items) e; + if(i.regarderDevantSoit() instanceof Heros) + return i.estRecolte(); + } + return false; + } +} diff --git a/src/modele/donnees/Bombe.java b/src/modele/donnees/Bombe.java index 674ad73..50e4551 100644 --- a/src/modele/donnees/Bombe.java +++ b/src/modele/donnees/Bombe.java @@ -7,12 +7,6 @@ public class Bombe extends Items { super(jeu); } - // TODO - @Override - public boolean estRecolte() { - return false; - } - // TODO @Override public String toString() { diff --git a/src/modele/donnees/Items.java b/src/modele/donnees/Items.java index 9dde3bb..0628eb4 100644 --- a/src/modele/donnees/Items.java +++ b/src/modele/donnees/Items.java @@ -1,5 +1,6 @@ package modele.donnees; +import modele.calculs.Direction; import modele.calculs.Jeu; public abstract class Items extends ElementFond implements ElementDynamique { @@ -17,5 +18,16 @@ public abstract class Items extends ElementFond implements ElementDynamique { return true; } - public abstract boolean estRecolte(); + @Override + public boolean avancerDirectionChoisie(Direction d) { + return jeu.deplacerEntite(this, d); + } + + public ElementPhysique regarderDevantSoit() { + return jeu.regarderDevantSoit(this); + } + + public boolean estRecolte() { + return avancerDirectionChoisie(null); + } }