public:vj1231:fsm:start
Diferencias
Muestra las diferencias entre dos versiones de la página.
Ambos lados, revisión anteriorRevisión previaPróxima revisión | Revisión previa | ||
public:vj1231:fsm:start [2025/10/08 15:36] – mperez | public:vj1231:fsm:start [2025/10/08 16:14] (actual) – [Ejemplo] mperez | ||
---|---|---|---|
Línea 7: | Línea 7: | ||
* Eventos o condiciones: | * Eventos o condiciones: | ||
* Acciones: Lo que el NPC hace mientras está en un estado determinado (animaciones, | * Acciones: Lo que el NPC hace mientras está en un estado determinado (animaciones, | ||
+ | |||
+ | |||
+ | ====== ¿Cómo se modela? ====== | ||
Las FSM pueden implementarse utilizando simples estructuras condicionales if-then-else (o switch/ | Las FSM pueden implementarse utilizando simples estructuras condicionales if-then-else (o switch/ | ||
- | Existen otras formas más robustas, modulares y limpias de implementar las FSM, uno de los paradigmas | + | Existen otras formas más robustas, modulares y limpias de implementar las FSM, uno de las técnicas |
+ | |||
+ | Las ventajas de este modelo es que cada estado encapsula su lógica lo que lo hace fácil de extender ya que añadir un nuevo estado solo requiere una nueva clase y vita grandes bloques de if/else que hacen el código ilegible. | ||
+ | |||
+ | ====== Componentes de la FSM ====== | ||
+ | ===== class State: ===== | ||
+ | |||
+ | Clase base para todos los estados del NPC. Cada estado define qué hacer al entrar, ejecutar y salir. | ||
+ | |||
+ | def enter(self, npc): → Acción al entrar en el estado. | ||
+ | |||
+ | def execute(self, | ||
+ | |||
+ | def exit(self, npc): → Acción al salir del estado. | ||
+ | |||
+ | def get_next_state_class(self, | ||
+ | |||
+ | ===== class StateMachine ===== | ||
+ | |||
+ | Etá clase implementa la Máquina de estados que gestiona el estado actual de un NPC. | ||
+ | |||
+ | ===== Nuevos estados ===== | ||
+ | |||
+ | Para definir nuevos estados se define una nueva clase que hereda de State: | ||
+ | |||
+ | <code python> | ||
+ | class TimidoPatrolState(State): | ||
+ | """ | ||
+ | Estado en el que el NPC tímido patrulla por el borde. | ||
+ | """ | ||
+ | ... | ||
+ | </ | ||
+ | |||
+ | ===== Transiciones entre estados ===== | ||
+ | |||
+ | Hay que definir para cada estado un diccionario denominado transitions con el evento que provoca una transición y a qué estado se mueve. | ||
+ | |||
+ | <code python> | ||
+ | # Definir transiciones para NPCTimido | ||
+ | TimidoPatrolState.transitions = {" | ||
+ | </ | ||
+ | |||
+ | ====== Ejemplo ====== | ||
+ | |||
+ | En esta imagen se muestra el comportamiento de tres NPCs distintos modelados usando FSM. Los estados se muestran en azul los eventos que provocan las transiciones entre estados aparecen sobre las flechas. | ||
+ | |||
+ | {{: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | {{: | ||
- | Las ventajas de este modelo es que cada estado encapsula su lógica lo que lo hace fácil de extender ya que añadir un nuevo estado solo requiere una nueva clase. Evita grandes bloques | + | Puedes ver y ejecutar el ejemplo en este {{ : |
- | + |
public/vj1231/fsm/start.1759937762.txt.gz · Última modificación: por mperez