Merge remote-tracking branch 'origin/main' into sliders

# Conflicts:
#	src/engine/event_handler.py
This commit is contained in:
Yannis 2024-01-12 23:17:46 +01:00
commit 93d568f996
7 changed files with 96 additions and 62 deletions

View file

@ -5,7 +5,7 @@ class Camera:
def __init__(self): def __init__(self):
self.x = 0 self.x = 0
self.y = 0 self.y = 0
self.zoom = 1. self.zoom = 1.75
# Décalage lors du mouvement du joueur # Décalage lors du mouvement du joueur
self.player_moving_offset = 100 self.player_moving_offset = 100

View file

@ -1,14 +1,11 @@
import json import json
from types import FunctionType from types import FunctionType
import src.engine.engine as engine
from src.engine.event_handler import EventHandler
class DialogsManager: class DialogsManager:
"""Classe qui gère la lecture des dialogues.""" """Classe qui gère la lecture des dialogues."""
def __init__(self, event_handler: EventHandler): def __init__(self, engine: 'engine.Engine'):
self.event_handler = event_handler self.engine = engine
self.current_dialogs = [] self.current_dialogs = []
self.current_dialog_id = -1 self.current_dialog_id = -1
self.dialogs = {} self.dialogs = {}
@ -31,8 +28,6 @@ class DialogsManager:
else: else:
self.next_dialog() self.next_dialog()
print("next")
def next_dialog(self): def next_dialog(self):
"""Passe au dialogue suivant. Appelle le callback si le dialogue est fini.""" """Passe au dialogue suivant. Appelle le callback si le dialogue est fini."""
self.current_dialog_id += 1 self.current_dialog_id += 1
@ -43,7 +38,8 @@ class DialogsManager:
self.current_dialog_id = -1 self.current_dialog_id = -1
self.writing_dialog = False self.writing_dialog = False
self.reading_dialog = False self.reading_dialog = False
self.event_handler.remove_button_area("next_dialog") self.engine.entity_manager.resume()
self.engine.event_handler.remove_button_area("next_dialog")
if self.dialogue_finished_callback is not None: if self.dialogue_finished_callback is not None:
self.dialogue_finished_callback() self.dialogue_finished_callback()
@ -52,7 +48,9 @@ class DialogsManager:
# Si un dialogue n'est pas déja lancé, on lance le dialogue au nom donné # Si un dialogue n'est pas déja lancé, on lance le dialogue au nom donné
if not self.reading_dialog: if not self.reading_dialog:
self.event_handler.register_button_area((0, 0, 1, 1), self.next_signal, "next_dialog", 2) self.engine.entity_manager.pause()
self.engine.event_handler.register_button_area((0, 0, 1, 1), self.next_signal, "next_dialog", 2)
self.current_dialogs = self.dialogs[name] self.current_dialogs = self.dialogs[name]
self.current_dialog_id = 0 self.current_dialog_id = 0

View file

@ -36,7 +36,7 @@ class Engine:
self.entity_manager = EntityManager(self.map_manager) self.entity_manager = EntityManager(self.map_manager)
self.boss_fight_manager = BossFightManager(self) self.boss_fight_manager = BossFightManager(self)
self.event_sheduler = EventSheduler(self) self.event_sheduler = EventSheduler(self)
self.dialogs_manager = DialogsManager(self.event_handler) self.dialogs_manager = DialogsManager(self)
self.menu_manager = MenuManager(self) self.menu_manager = MenuManager(self)
self.sound_manager = SoundManager(60) self.sound_manager = SoundManager(60)

View file

@ -11,6 +11,8 @@ class Entity:
self.x = 8 self.x = 8
self.y = 8 self.y = 8
self.locked = False # Variable définissant si l'entité est bloqué ou non (.lock() et .unlock())
self.direction = 0 # 0 : tourné vers la droite (ou sens par défaut), 1 : tourné vers la gauche (ou retourné) self.direction = 0 # 0 : tourné vers la droite (ou sens par défaut), 1 : tourné vers la gauche (ou retourné)
# Variables utilisées pour détecter les mouvements # Variables utilisées pour détecter les mouvements
@ -117,6 +119,8 @@ class Entity:
def move(self, x: float, y: float, map_manager: MapManager): def move(self, x: float, y: float, map_manager: MapManager):
"""Fait bouger l'entité en tenant compte des collisions.""" """Fait bouger l'entité en tenant compte des collisions."""
if not self.locked: # Si l'entité n'est pas verrouillée on calcul le mouvement
# On vérifie le sens du mouvement pour changer self.direction # On vérifie le sens du mouvement pour changer self.direction
if x > 0: if x > 0:
self.direction = 0 self.direction = 0
@ -131,6 +135,7 @@ class Entity:
y = y/initial_speed*self.max_speed y = y/initial_speed*self.max_speed
# On simule le mouvement. Si on ne rencontre pas de collision, on applique le mouvement # On simule le mouvement. Si on ne rencontre pas de collision, on applique le mouvement
if not self.get_collisions(self.x + x, self.y, map_manager): if not self.get_collisions(self.x + x, self.y, map_manager):
self.x += x self.x += x
else: else:
@ -164,5 +169,14 @@ class Entity:
self.y += i self.y += i
def link_animation(self, name: str): def link_animation(self, name: str):
"""Met à jour l'animation en cours de l'entité.""" """Met à jour l'animation en cours de l'entitée."""
self.animation_name = name self.animation_name = name
def lock(self):
"""Bloque tout les mouvements de l'entitée"""
self.locked = True
def unlock(self):
"""Débloque tout les mouvements de l'entitée"""
self.locked = False

View file

@ -8,6 +8,8 @@ class EntityManager:
self.entities: dict[str:Entity] = {} self.entities: dict[str:Entity] = {}
self.player_entity_name = "" self.player_entity_name = ""
self.map_manager = map_manager self.map_manager = map_manager
self.locked_before_pause: list[Entity] = []
self.paused = False
def register_entity(self, name: str) -> Entity: def register_entity(self, name: str) -> Entity:
"""Crée une entité et l'enregistre dans un dictionnaire.""" """Crée une entité et l'enregistre dans un dictionnaire."""
@ -32,7 +34,7 @@ class EntityManager:
if entity.life_points == 0: if entity.life_points == 0:
self.entities.pop(entity_name) self.entities.pop(entity_name)
if entity.brain is not None: if entity.brain is not None and not self.paused:
entity.brain.update(delta) entity.brain.update(delta)
if self.player_entity_name: if self.player_entity_name:
@ -49,3 +51,22 @@ class EntityManager:
def get_by_name(self, name: str) -> Entity: def get_by_name(self, name: str) -> Entity:
"""Donne l'entité avec le nom donné.""" """Donne l'entité avec le nom donné."""
return self.entities[name] return self.entities[name]
def pause(self):
"""Met en pause tout les mouvements de toutes les entitées"""
for e in self.get_all_entities():
if e.locked:
self.locked_before_pause.append(e)
else:
e.lock()
self.paused = True
def resume(self):
"""Reprend les mouvement de toutes les entitées qui n'étaient pas lock avant l'appel de .pause()"""
for e in self.get_all_entities():
if not e in self.locked_before_pause:
e.unlock()
self.paused = False
self.locked_before_pause = []

View file

@ -1,7 +1,6 @@
import math import math
from types import FunctionType from types import FunctionType
import pygame.display
from pygame import event, display from pygame import event, display
from pygame.locals import * from pygame.locals import *
@ -102,7 +101,7 @@ class EventHandler:
def update(self): def update(self):
"""Vérifie s'il y a de nouvelles interactions et les traites.""" """Vérifie s'il y a de nouvelles interactions et les traites."""
window_size = pygame.display.get_window_size() window_size = display.get_window_size()
# Récupère les événements # Récupère les événements
for e in event.get(): for e in event.get():
@ -120,6 +119,7 @@ class EventHandler:
if self.get_click_collision(area[0], e.pos, area[2]): if self.get_click_collision(area[0], e.pos, area[2]):
area[1]() area[1]()
for area in self.sliders_area: for area in self.sliders_area:
if self.get_click_collision( if self.get_click_collision(
(area[0][0]-area[0][2]/2, area[0][1]-area[0][3]/2, area[0][2], area[0][3]), (area[0][0]-area[0][2]/2, area[0][1]-area[0][3]/2, area[0][2], area[0][3]),
@ -230,3 +230,4 @@ class EventHandler:
self.engine.camera.target_zoom *= 1.01 self.engine.camera.target_zoom *= 1.01
if K_c in self.key_pressed: if K_c in self.key_pressed:
self.engine.camera.target_zoom *= 0.99 self.engine.camera.target_zoom *= 0.99

View file

@ -117,7 +117,7 @@ class Renderer:
# Conteur de FPS en mode DEBUG # Conteur de FPS en mode DEBUG
if self.engine.DEBUG_MODE: if self.engine.DEBUG_MODE:
self.window.blit(font.SysFont("Arial", 20).render(f"FPS: {round(self.engine.clock.get_fps())}", True, (255, 0, 0)), self.window.blit(font.SysFont("Arial", 20).render(f"FPS: {round(self.engine.clock.get_fps())}, Game Status: {'Paused' if self.engine.entity_manager.paused else 'Playing'}", True, (255, 0, 0)),
(0, 0)) (0, 0))
player = self.engine.entity_manager.get_by_name('player') player = self.engine.entity_manager.get_by_name('player')
self.window.blit(font.SysFont("Arial", 20).render(f"X: {round(player.x, 2)} Y:{round(player.y, 2)}", self.window.blit(font.SysFont("Arial", 20).render(f"X: {round(player.x, 2)} Y:{round(player.y, 2)}",