init
This commit is contained in:
@@ -48,3 +48,9 @@ Thumbs.db
|
|||||||
*.mov
|
*.mov
|
||||||
*.wmv
|
*.wmv
|
||||||
|
|
||||||
|
__pycache__/
|
||||||
|
.spyproject/
|
||||||
|
.pydevproject
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,17 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<projectDescription>
|
||||||
|
<name>elironwars</name>
|
||||||
|
<comment></comment>
|
||||||
|
<projects>
|
||||||
|
</projects>
|
||||||
|
<buildSpec>
|
||||||
|
<buildCommand>
|
||||||
|
<name>org.python.pydev.PyDevBuilder</name>
|
||||||
|
<arguments>
|
||||||
|
</arguments>
|
||||||
|
</buildCommand>
|
||||||
|
</buildSpec>
|
||||||
|
<natures>
|
||||||
|
<nature>org.python.pydev.pythonNature</nature>
|
||||||
|
</natures>
|
||||||
|
</projectDescription>
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"name": "Hector",
|
||||||
|
"max_pv": 20,
|
||||||
|
"current_pv": 20,
|
||||||
|
"strength": 5,
|
||||||
|
"protection": 3,
|
||||||
|
"speed": 2,
|
||||||
|
"mob_type": 0
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"name": "Jamin",
|
||||||
|
"max_pv": 30,
|
||||||
|
"current_pv": 30,
|
||||||
|
"strength": 5,
|
||||||
|
"protection": 1,
|
||||||
|
"speed": 2,
|
||||||
|
"mob_type": 0
|
||||||
|
}
|
||||||
@@ -0,0 +1,58 @@
|
|||||||
|
from character_builder import CharacterBuilder
|
||||||
|
from level_one import Level
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
def action_menu():
|
||||||
|
""" Menu Action du niveau """
|
||||||
|
print("\n------ Menu Action ------\n")
|
||||||
|
print("Pièce Suivante :\t 1")
|
||||||
|
print("Combat : \t\t\t 2")
|
||||||
|
print("Fuir : \t\t\t\t 3")
|
||||||
|
print("Quitter :\t\t\t 4")
|
||||||
|
return int(input("\nChoix : "))
|
||||||
|
|
||||||
|
|
||||||
|
# Exemple d'utilisation
|
||||||
|
if __name__ == "__main__":
|
||||||
|
loaded_character = CharacterBuilder.load_character("Jamin")
|
||||||
|
if loaded_character:
|
||||||
|
print(loaded_character)
|
||||||
|
|
||||||
|
level = Level(2, CharacterBuilder.load_character("Jamin"))
|
||||||
|
player = level.player
|
||||||
|
rooms = level.rooms
|
||||||
|
number_room = len(rooms)
|
||||||
|
print(f"Nombre de pièce dans le donjon : {number_room}")
|
||||||
|
|
||||||
|
while level.exit_level:
|
||||||
|
os.system('cls' if os.name == 'nt' else 'clear')
|
||||||
|
match action_menu():
|
||||||
|
case 1:
|
||||||
|
if level.current_room_index >= number_room:
|
||||||
|
print("fin du donjon !")
|
||||||
|
break
|
||||||
|
room = rooms[level.current_room_index]
|
||||||
|
print(f"Pièce actuelle : {level.current_room_index}")
|
||||||
|
if room is not None:
|
||||||
|
for mob in room:
|
||||||
|
print(f"Un {mob.name} est devant toi !")
|
||||||
|
match action_menu():
|
||||||
|
case 2:
|
||||||
|
level.combat(mob, player)
|
||||||
|
if player.current_pv <= 0:
|
||||||
|
print("!!!!!!!!! Joueur mort !!!!!!!!!!")
|
||||||
|
break
|
||||||
|
if mob.current_pv == 0:
|
||||||
|
print(f"Le {mob.name} est mort !!")
|
||||||
|
case 3:
|
||||||
|
print("Tu fuis la pièce")
|
||||||
|
else:
|
||||||
|
print("\n ------ Pièce vide ------ \n")
|
||||||
|
player.current_pv = player.max_pv
|
||||||
|
level.current_room_index += 1
|
||||||
|
case 4:
|
||||||
|
level.exit_level = False
|
||||||
|
print(f"Au revoir {player.name} !")
|
||||||
|
case _:
|
||||||
|
print("Mauvais choix")
|
||||||
+65
@@ -0,0 +1,65 @@
|
|||||||
|
class BaseMob:
|
||||||
|
"""Classe de base représentant un mob avec différentes caractéristiques."""
|
||||||
|
|
||||||
|
# Types possibles
|
||||||
|
FRIEND = 0
|
||||||
|
NEUTRAL = 1
|
||||||
|
ENEMY = 2
|
||||||
|
|
||||||
|
def __init__(self, name, max_pv, strength, protection, speed, mob_type):
|
||||||
|
"""
|
||||||
|
Initialisation d'un nouveau mob.
|
||||||
|
|
||||||
|
:param name: Nom du mob
|
||||||
|
:param max_pv: Points de vie maximum
|
||||||
|
:param strength: Force d'attaque
|
||||||
|
:param protection: Protection contre les dommages
|
||||||
|
:param speed: Vitesse d'attaque (nombre d'attaques par tour)
|
||||||
|
:param mob_type: Type de mob (0 = Ami, 1 = Neutre, 2 = Ennemi)
|
||||||
|
"""
|
||||||
|
self.name = name
|
||||||
|
self.max_pv = max_pv
|
||||||
|
self.current_pv = max_pv
|
||||||
|
self.strength = strength
|
||||||
|
self.protection = protection
|
||||||
|
self.speed = speed
|
||||||
|
self.mob_type = mob_type
|
||||||
|
|
||||||
|
def change_type(self, new_type):
|
||||||
|
"""
|
||||||
|
Change le type du mob.
|
||||||
|
|
||||||
|
:param new_type: Nouveau type (0 = Ami, 1 = Neutre, 2 = Ennemi)
|
||||||
|
"""
|
||||||
|
self.mob_type = new_type
|
||||||
|
|
||||||
|
def change_pv(self, pv_modifier):
|
||||||
|
"""
|
||||||
|
Modifie les points de vie actuels du mob.
|
||||||
|
|
||||||
|
:param pv_modifier: Valeur par laquelle modifier les PV (positive pour guérir, négative pour infliger des dégâts)
|
||||||
|
"""
|
||||||
|
if pv_modifier > 0:
|
||||||
|
# Ajout de PV (guérison)
|
||||||
|
self.current_pv = min(self.max_pv, self.current_pv + pv_modifier)
|
||||||
|
else:
|
||||||
|
# Retrait de PV (dommages)
|
||||||
|
damage = pv_modifier + self.protection
|
||||||
|
self.current_pv = max(0, self.current_pv + damage)
|
||||||
|
|
||||||
|
def perform_attack(self, target):
|
||||||
|
"""
|
||||||
|
Le mob attaque une cible.
|
||||||
|
|
||||||
|
:param target: Le mob cible de l'attaque
|
||||||
|
"""
|
||||||
|
for _ in range(self.speed):
|
||||||
|
if target.current_pv <= 0:
|
||||||
|
break
|
||||||
|
target.change_pv(-self.strength)
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
"""Retourne une représentation sous forme de chaîne du mob."""
|
||||||
|
return (f"{self.name} - PV: {self.current_pv}/{self.max_pv}, "
|
||||||
|
f"Force: {self.strength}, Protection: {self.protection}, "
|
||||||
|
f"Vitesse: {self.speed}")
|
||||||
@@ -0,0 +1,66 @@
|
|||||||
|
from base_mob import BaseMob
|
||||||
|
import json
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
class CharacterBuilder:
|
||||||
|
@staticmethod
|
||||||
|
def build_character():
|
||||||
|
"""Demande à l'utilisateur de saisir les attributs du personnage."""
|
||||||
|
print("Création d'un nouveau personnage :")
|
||||||
|
name = input("Nom du personnage : ")
|
||||||
|
max_pv = int(input("Points de vie maximum : "))
|
||||||
|
strength = int(input("Force : "))
|
||||||
|
protection = int(input("Protection : "))
|
||||||
|
speed = int(input("Vitesse : "))
|
||||||
|
mob_type = 0
|
||||||
|
return BaseMob(name, max_pv, strength, protection, speed, mob_type)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def save_character(character):
|
||||||
|
"""Enregistre un personnage dans un fichier JSON."""
|
||||||
|
character_data = {
|
||||||
|
"name": character.name,
|
||||||
|
"max_pv": character.max_pv,
|
||||||
|
"current_pv": character.current_pv,
|
||||||
|
"strength": character.strength,
|
||||||
|
"protection": character.protection,
|
||||||
|
"speed": character.speed,
|
||||||
|
"mob_type": character.mob_type
|
||||||
|
}
|
||||||
|
filename = character.name + ".json"
|
||||||
|
with open(filename, "w",encoding='UTF-8') as file:
|
||||||
|
json.dump(character_data, file, indent=4)
|
||||||
|
print(f"Personnage enregistré dans {filename}.")
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def load_character(name):
|
||||||
|
"""Charge un personnage à partir d'un fichier JSON."""
|
||||||
|
filename = name + ".json"
|
||||||
|
if not os.path.exists(filename):
|
||||||
|
print(f"Erreur : Le fichier {filename} n'existe pas.")
|
||||||
|
return None
|
||||||
|
|
||||||
|
try:
|
||||||
|
with open(filename, "r",encoding='UTF-8') as file:
|
||||||
|
character_data = json.load(file)
|
||||||
|
|
||||||
|
# Vérification des clés essentielles dans le JSON pour éviter les erreurs
|
||||||
|
required_keys = ["name", "max_pv", "current_pv",
|
||||||
|
"strength", "protection", "speed", "mob_type"]
|
||||||
|
if not all(key in character_data for key in required_keys):
|
||||||
|
print(f"Erreur : Le fichier {filename} ne contient pas toutes les clés nécessaires.")
|
||||||
|
return None
|
||||||
|
|
||||||
|
# Construction du personnage
|
||||||
|
return BaseMob(
|
||||||
|
name=character_data["name"],
|
||||||
|
max_pv=character_data["max_pv"],
|
||||||
|
strength=character_data["strength"],
|
||||||
|
protection=character_data["protection"],
|
||||||
|
speed=character_data["speed"],
|
||||||
|
mob_type=character_data["mob_type"]
|
||||||
|
)
|
||||||
|
except json.JSONDecodeError:
|
||||||
|
print(f"Erreur : Le fichier {filename} n'est pas un JSON valide.")
|
||||||
|
return None
|
||||||
@@ -0,0 +1,71 @@
|
|||||||
|
""" Class Level """
|
||||||
|
import random
|
||||||
|
import mobs_utils
|
||||||
|
from character_builder import CharacterBuilder
|
||||||
|
|
||||||
|
|
||||||
|
class Level():
|
||||||
|
""" Class Level """
|
||||||
|
|
||||||
|
def __init__(self, difficulty, player):
|
||||||
|
""" Chargement du niveau """
|
||||||
|
print("Loading Level")
|
||||||
|
self.mobs_in_level = mobs_utils.generate_random_mob_list(
|
||||||
|
random.randint(2, difficulty))
|
||||||
|
self.exit_level = True
|
||||||
|
self.player = player
|
||||||
|
self.rooms = mobs_utils.generate_random_rooms(
|
||||||
|
self.mobs_in_level, difficulty) # Liste des pièces du niveau
|
||||||
|
self.current_room_index = 0 # Index de la pièce actuelle
|
||||||
|
|
||||||
|
print("Level Loaded")
|
||||||
|
|
||||||
|
def combat(self, mob, player):
|
||||||
|
while (mob.current_pv > 0 and player.current_pv > 0):
|
||||||
|
if mob.speed > player.speed:
|
||||||
|
mob.perform_attack(player)
|
||||||
|
player.perform_attack(mob)
|
||||||
|
else:
|
||||||
|
player.perform_attack(mob)
|
||||||
|
mob.perform_attack(player)
|
||||||
|
print(f"{player.name} - {player.current_pv} PV")
|
||||||
|
print(f"{mob.name} - {mob.current_pv} PV")
|
||||||
|
|
||||||
|
|
||||||
|
def action_menu():
|
||||||
|
""" Menu Action du niveau """
|
||||||
|
print("Pièce Suivante :\t1")
|
||||||
|
print("Quitter :\t\t4")
|
||||||
|
return int(input("Choix : "))
|
||||||
|
|
||||||
|
# Exemple d'utilisation
|
||||||
|
if __name__ == "__main__":
|
||||||
|
level = Level(2, CharacterBuilder.load_character("Jamin"))
|
||||||
|
player = level.player
|
||||||
|
rooms = level.rooms
|
||||||
|
number_room = len(rooms)
|
||||||
|
print(f"Nombre de pièce dans le donjon : {number_room}")
|
||||||
|
|
||||||
|
while level.exit_level:
|
||||||
|
match action_menu():
|
||||||
|
case 1:
|
||||||
|
if level.current_room_index >= number_room:
|
||||||
|
print("fin du donjon !")
|
||||||
|
break
|
||||||
|
room = rooms[level.current_room_index]
|
||||||
|
print(f"Pièce actuelle : {level.current_room_index}")
|
||||||
|
if room:
|
||||||
|
for mob in room:
|
||||||
|
level.combat(mob, player)
|
||||||
|
if player.current_pv <= 0:
|
||||||
|
print("!!!!!!!!! Joueur mort !!!!!!!!!!")
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
print("Pièce vide")
|
||||||
|
player.current_pv = player.max_pv
|
||||||
|
level.current_room_index += 1
|
||||||
|
case 4:
|
||||||
|
level.exit_level = False
|
||||||
|
print(f"Au revoir {player.name} !")
|
||||||
|
case _:
|
||||||
|
print("Mauvais choix")
|
||||||
@@ -0,0 +1,26 @@
|
|||||||
|
|
||||||
|
# def main_loop(breaker:bool):
|
||||||
|
# pass
|
||||||
|
|
||||||
|
# def menu ():
|
||||||
|
# print("Nouvelle partie :\t1")
|
||||||
|
# print("Charger :\t\t2")
|
||||||
|
# print("Option :\t\t3")
|
||||||
|
# print("Quitter :\t\t4")
|
||||||
|
# return int(input("Choix : "))
|
||||||
|
|
||||||
|
|
||||||
|
# choix = menu()
|
||||||
|
|
||||||
|
# match choix:
|
||||||
|
# case 1:
|
||||||
|
# print("Nouvelle partie")
|
||||||
|
# case 2:
|
||||||
|
# print("Charger")
|
||||||
|
# case 3:
|
||||||
|
# print("Option")
|
||||||
|
# case 4:
|
||||||
|
# print("Quitter")
|
||||||
|
# case _:
|
||||||
|
# print("Mauvais choix")
|
||||||
|
|
||||||
@@ -0,0 +1,49 @@
|
|||||||
|
import random
|
||||||
|
from base_mob import BaseMob
|
||||||
|
|
||||||
|
# Créer des instances de BaseMob
|
||||||
|
yanaar = BaseMob("Yanaar", 15, 2, 1, 3, 2)
|
||||||
|
ulnarain = BaseMob("Ulnarain", 20, 3, 3, 2, 2)
|
||||||
|
skroll = BaseMob("Skroll", 25, 5, 3, 1, 2)
|
||||||
|
|
||||||
|
# Liste d'instances de BaseMob (au lieu d'un ensemble pour autoriser des doublons)
|
||||||
|
mobs_list = [yanaar, skroll, ulnarain]
|
||||||
|
|
||||||
|
|
||||||
|
def generate_random_mob_list(max_mobs):
|
||||||
|
"""
|
||||||
|
Génère une liste aléatoire de mobs à partir de la liste des instances disponibles.
|
||||||
|
|
||||||
|
:param max_mobs: Le nombre maximum de mobs dans la liste générée.
|
||||||
|
:return: Une liste de mobs sélectionnés aléatoirement.
|
||||||
|
"""
|
||||||
|
if max_mobs <= 0:
|
||||||
|
return []
|
||||||
|
|
||||||
|
num_mobs = random.randint(2, max_mobs)
|
||||||
|
selected_mobs = [random.choice(mobs_list) for _ in range(num_mobs)]
|
||||||
|
return selected_mobs
|
||||||
|
|
||||||
|
|
||||||
|
def generate_random_rooms(mobs_in_level, num_rooms):
|
||||||
|
"""
|
||||||
|
Génère un nombre spécifié de pièces et y distribue les mobs disponibles.
|
||||||
|
|
||||||
|
:param mobs_in_level: Liste des mobs disponibles pour le niveau.
|
||||||
|
:param num_rooms: Nombre total de pièces à générer.
|
||||||
|
:return: Une liste de pièces, chaque pièce contenant un ou plusieurs mobs, ou étant vide si aucun mob n'est disponible.
|
||||||
|
"""
|
||||||
|
rooms = []
|
||||||
|
|
||||||
|
for _ in range(num_rooms):
|
||||||
|
if len(mobs_in_level) > 0:
|
||||||
|
# Si des mobs sont disponibles, ajouter le premier mob à la pièce
|
||||||
|
new_room = []
|
||||||
|
for x in range(random.randint(1, len(mobs_in_level))):
|
||||||
|
new_room.append(mobs_in_level.pop(0))
|
||||||
|
rooms.append(new_room)
|
||||||
|
else:
|
||||||
|
# Ajouter une pièce vide si aucun mob n'est disponible
|
||||||
|
rooms.append(None)
|
||||||
|
|
||||||
|
return rooms
|
||||||
Reference in New Issue
Block a user