diff options
| author | Matheus <matheus.guedes.mg.m@gmail.com> | 2025-09-09 19:09:34 -0300 |
|---|---|---|
| committer | Matheus <matheus.guedes.mg.m@gmail.com> | 2025-09-09 19:09:34 -0300 |
| commit | c6bbb834f7758027c0df338f1520f34fad3befea (patch) | |
| tree | 1818cd23c24be16fbe19b16dd0a510874d440d83 /scripts/Entities/Actions/Action.cs | |
| parent | f1b51bed52ffbd90b5b7cc8dcfc6f0484bbbeb3c (diff) | |
Organização
Diffstat (limited to 'scripts/Entities/Actions/Action.cs')
| -rw-r--r-- | scripts/Entities/Actions/Action.cs | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/scripts/Entities/Actions/Action.cs b/scripts/Entities/Actions/Action.cs new file mode 100644 index 0000000..b2d6a4b --- /dev/null +++ b/scripts/Entities/Actions/Action.cs @@ -0,0 +1,69 @@ +using Godot; +using TheLegendOfGustav.Entities.Actors; +using TheLegendOfGustav.Map; + +namespace TheLegendOfGustav.Entities.Actions; + +/// <summary> +/// <c>Action</c> representa uma ação no jogo efetuada por um ator. +/// Ações são geradas pelo jogador e pela IA, elas regem os atores do jogo. +/// </summary> +public abstract partial class Action : RefCounted +{ + private Actor actor; + + private int cost; + + public Action(Actor actor) + { + Actor = actor; + // Custo base, subclasses podem sobreescrever isto se quiserem. + Cost = 10; + } + + /// <summary> + /// O ator que realiza a ação. + /// </summary> + public Actor Actor + { + get => actor; + private set + { + actor = value; + } + } + + /// <summary> + /// O custo da ação. + /// </summary> + protected int Cost + { + get => cost; + set + { + cost = value; + } + } + + /// <summary> + /// É conveniente ter acesso ao mapa dentro de uma ação. + /// </summary> + protected MapData MapData + { + get => actor.MapData; + } + + /// <summary> + /// Método que executa a ação. Subclasses da ação devem implementar este método. + /// <example> + /// Exemplo: + /// <code> + /// Action action = new Action(actor); + /// /* . . . */ + /// action.Perform(); + /// </code> + /// </example> + /// </summary> + /// <returns>Se a ação foi executada ou não.</returns> + public abstract bool Perform(); +} |
