diff --git a/Sources/Console/Program.cs b/Sources/Console/Program.cs index f94eb67..5a3382d 100644 --- a/Sources/Console/Program.cs +++ b/Sources/Console/Program.cs @@ -10,7 +10,7 @@ using System.Reflection.PortableExecutable; // Déclaration des Managers (et de leur méthode de sauvegarde) UserManager userMngr = new UserManager(new LoaderXml()); -MonsterManager monsterBase = new MonsterManager(new LoaderXml()); +MonsterManager monsterBase = new MonsterManager(new LoaderStub()); // Variables statiques bool isUserConnected = false; diff --git a/Sources/Modèle/Monstre.cs b/Sources/Modèle/Monstre.cs index 1b272a1..54fb46f 100644 --- a/Sources/Modèle/Monstre.cs +++ b/Sources/Modèle/Monstre.cs @@ -16,7 +16,7 @@ namespace Model { if (PropertyChanged != null) { - PropertyChanged(this, new PropertyChangedEventArgs(propertyName)); + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName)); } } @@ -89,5 +89,22 @@ namespace Model throw new ArgumentException("Un monstre doit avoir un nom, une description et une dangerosité!"); } } + + public override string ToString() + => $"{Name} ({Description})"; + + public bool Equals(Monstre? other) + => Name.Equals(other.Name); + + public override bool Equals(object? obj) + { + if (ReferenceEquals(obj, null)) return false; + if (ReferenceEquals(obj, this)) return true; + if (GetType() != obj.GetType()) return false; + return Equals(obj as Monstre); + } + + public override int GetHashCode() + => base.GetHashCode(); } } \ No newline at end of file diff --git a/Sources/Persistance/LoaderStub.cs b/Sources/Persistance/LoaderStub.cs index 13cb959..2166ecb 100644 --- a/Sources/Persistance/LoaderStub.cs +++ b/Sources/Persistance/LoaderStub.cs @@ -12,7 +12,7 @@ namespace Persistance /// Le stub "émule" une base de données, elle permet simplement d'imiter le rôle du stockage des /// données, par exemple en ajoutant plusieurs utilisateurs dans une base de données. /// - public class LoaderStub : IUserDataManager + public class LoaderStub : IUserDataManager, IMonsterDataManager { public LoaderStub() { } public List loadUsers() ///CHANGER VISIBILITEE, CAR PAS BIEN DE LAISSER A TOUT LE MONDE @@ -39,7 +39,7 @@ namespace Persistance lm.Add(new Monstre(2, "Mouton", "passif", "Je suis présent un peu partout, sauf dnas le desert.", new List { "Avec une cisaille il est possible de rasé la laine d'un mouton, il se retoruvera sans laine.", "Pour faire repousser la laine d'un mouton il faut qu'il ai de l'herbe sous ses pattes pour qu'il puisse manger. Une fois manger la laine repousse instantanément !" }, new List { "Apparence1", "App2", "App3" }, new List { })); lm.Add(new Monstre(3, "Cochon", "passif", "Je suis un animal présent partout, sauf dans le desert ou il fait trop chaud pour moi.", new List{ "La reproduction de cochon peut se faire avec des carottes et des patates crues."}, new List { "Apparence1", "App2", "App3" }, new List { })); lm.Add(new Monstre(4, "Warden", "boss", "Je ne vous voit pas mais je sais où vous êtes", new List { "Le warden est aveugle mais il entend tous les bruit autour de lui.", "Il apparait dans une caverne spécial appeler les abîmes quand on y marche en faisant trop de bruit.", "Il s'agit du seul monstre qui ai une animation d'apparation, il sort du sol.", "Il est capable de tirer des rayon laser à l'endroit d'où proviennes les bruit qu'il entend." }, new List { "Une seul apparence pour lui" }, new List { })); - lm.Add(new Monstre(5, "Ender dragon", "boss", "Si vous arrivez à me vaincre, vous aurez accompli tout ce qui était possible de faire dans ce monde.", new List { "L'Ender dragon est le boss de fin de minecraft.", "Pour le vaincre il faut trouver le portail inter-dimensionnel qui se cache quelque part dans votre monde.", "Une fois vaincu, il laissera son oeuf ainsi qu'un portail qui vous permettra de rentrer chez vous." }, new List { "Une seul apparence pour lui" }, new List { })); + lm.Add(new Monstre(5, "EnderDragon", "boss", "Si vous arrivez à me vaincre, vous aurez accompli tout ce qui était possible de faire dans ce monde.", new List { "L'Ender dragon est le boss de fin de minecraft.", "Pour le vaincre il faut trouver le portail inter-dimensionnel qui se cache quelque part dans votre monde.", "Une fois vaincu, il laissera son oeuf ainsi qu'un portail qui vous permettra de rentrer chez vous." }, new List { "Une seul apparence pour lui" }, new List { })); lm.Add(new Monstre(6, "Wither", "boss", "Une fois que je vous ai aperçue, je ne vous lâcherais plus jusqu'à ce que mort s'ensuive.", new List { "Pour le faire apparaitre, il vous faudrat la tête de 3 wither squelette.", "Le wither lance des tête qui repousse instantanément.", "Ces têtes peuvent vous empoissoné jusqu'à la mort" }, new List { "Apparence de chargement", "Apparence d'attaque", "Apparence mid life" }, new List { })); lm.Add(new Monstre(7, "Vache", "passif", "Je suis un peu partout dans le monde, mais plus particulièrement dans les plaines.", new List { "Les vaches apparaissent par groupe de quatres minimum.", "Elle peuvent donner du lait grâce à un sceau, ce lait enlève tout les effets de potion que vous aurez" }, new List { "Vache de base", "vache champignon" }, new List { })); lm.Add(new Monstre(8, "Loup", "passif", "Je deviens vite aggressif lorsque l'on m'attaque.", new List { "Les loups peuvent être apprivoisé grâce à des os.", " Une fois apprivoisé" }, new List { "Apparence nature", "Apparence méchant", "Apparence apprivoisé" }, new List { })); @@ -50,7 +50,7 @@ namespace Persistance lm.Add(new Monstre(13, "Phantom", "hostile", "Dormez ou je viendrais", new List { "Le phantom apparaît lorsque vous ne dormez pas pendant plus de trois jour d'affilés.", "Ils sont difficile à atteindre pusiqu'il vole plutôt vite" }, new List{"Apparence 1"}, new List { })); lm.Add(new Monstre(14, "Enderman", "hostile", "Ne me regardez pas ! ", new List { "Si vous regardez un enderman dans les yeux, il se mettra à vous attaquer, autrement, il est inoffensif", " Gardez le contact visuel avec, lui le fera changer d'avis au bout de quelques secondes sur l'agressivité qu'il a envers vous.", "Il est capable de prendre des blocks et les reposer ailleurs." }, new List { "apparence 1", "apparence avec un bloc" }, new List { })); lm.Add(new Monstre(15, "Slime", "hostile", "Je connais le multiclonage !", new List { "Les slimes peuvent apparaître avec des tailles différentes.", "S'il n'est pas trop petit, il se divisera en quatre."}, new List { "Apparencegrand", "apparence petit"}, new List { })); - lm.Add(new Monstre(16, "Araignée", "hostile", " je sais pas quoi mettre mdrrrrr", new List { "L'arraignée est capable de grimper au mur", " Si vous en rencontrait une en journée et en extérieur elle sera inoffensive, mais dans une caverne ou pendant la nuit elle vous attaquera." }, new List { "une seule apparence" }, new List { })); + lm.Add(new Monstre(16, "Araignee", "hostile", " je sais pas quoi mettre mdrrrrr", new List { "L'arraignée est capable de grimper au mur", " Si vous en rencontrait une en journée et en extérieur elle sera inoffensive, mais dans une caverne ou pendant la nuit elle vous attaquera." }, new List { "une seule apparence" }, new List { })); return lm; } @@ -58,5 +58,10 @@ namespace Persistance { Console.WriteLine("This is a stub, so no 'save' possible !"); } + + void IMonsterDataManager.saveMonsters(List monstres) + { + Console.WriteLine("This is a stub, so no 'save' possible !"); + } } } \ No newline at end of file diff --git a/Sources/Persistance/MonsterManager.cs b/Sources/Persistance/MonsterManager.cs index 39693ac..e9d1a11 100644 --- a/Sources/Persistance/MonsterManager.cs +++ b/Sources/Persistance/MonsterManager.cs @@ -40,7 +40,8 @@ namespace Persistance select m).ToList(); // LINQ } - public MonsterManager(IMonsterDataManager dataMngr) { + public MonsterManager(IMonsterDataManager dataMngr) + { Pers = dataMngr; ListMonsters = new LoaderStub().loadMonsters(); } diff --git a/Sources/Vues/Accueil.xaml b/Sources/Vues/Accueil.xaml index addf680..8770cc6 100644 --- a/Sources/Vues/Accueil.xaml +++ b/Sources/Vues/Accueil.xaml @@ -67,12 +67,15 @@ HeightRequest="100" />