2022-11-20 22:56:42 +02:00
|
|
|
/*
|
2022-12-11 23:16:23 +02:00
|
|
|
* BattleActionsController.h, part of VCMI engine
|
2022-11-20 22:56:42 +02:00
|
|
|
*
|
|
|
|
* Authors: listed in file AUTHORS in main folder
|
|
|
|
*
|
|
|
|
* License: GNU General Public License v2.0 or later
|
|
|
|
* Full text of license available in license.txt file, in main folder
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "../../lib/battle/CBattleInfoCallback.h"
|
|
|
|
|
2022-11-29 02:00:08 +02:00
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2022-11-20 22:56:42 +02:00
|
|
|
class BattleAction;
|
2023-01-21 19:42:44 +02:00
|
|
|
namespace spells {
|
|
|
|
class Caster;
|
2023-01-29 14:27:57 +02:00
|
|
|
enum class Mode;
|
2023-01-21 19:42:44 +02:00
|
|
|
}
|
2022-11-29 02:00:08 +02:00
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|
|
|
|
|
2022-12-09 13:26:17 +02:00
|
|
|
class BattleInterface;
|
2022-11-20 22:56:42 +02:00
|
|
|
|
|
|
|
enum class MouseHoveredHexContext
|
|
|
|
{
|
|
|
|
UNOCCUPIED_HEX,
|
|
|
|
OCCUPIED_HEX
|
|
|
|
};
|
|
|
|
|
2022-12-11 23:16:23 +02:00
|
|
|
/// Class that controls actions that can be performed by player, e.g. moving stacks, attacking, etc
|
|
|
|
/// As well as all relevant feedback for these actions in user interface
|
2022-12-09 13:26:17 +02:00
|
|
|
class BattleActionsController
|
2022-11-20 22:56:42 +02:00
|
|
|
{
|
2022-12-13 13:58:16 +02:00
|
|
|
BattleInterface & owner;
|
2023-04-06 23:27:03 +02:00
|
|
|
|
|
|
|
/// mouse or touchscreen click mode
|
|
|
|
bool touchscreenMode = false;
|
|
|
|
|
2022-12-11 23:16:23 +02:00
|
|
|
/// all actions possible to call at the moment by player
|
|
|
|
std::vector<PossiblePlayerBattleAction> possibleActions;
|
2022-11-20 22:56:42 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// spell for which player's hero is choosing destination
|
|
|
|
std::shared_ptr<BattleAction> heroSpellToCast;
|
2022-11-20 22:56:42 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// cached message that was set by this class in status bar
|
|
|
|
std::string currentConsoleMsg;
|
2022-11-20 22:56:42 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// if true, active stack could possibly cast some target spell
|
2023-03-25 00:48:14 +02:00
|
|
|
std::vector<const CSpell *> creatureSpells;
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-03-31 21:15:24 +02:00
|
|
|
/// stack that has been selected as first target for multi-target spells (Teleport & Sacrifice)
|
|
|
|
const CStack * selectedStack;
|
|
|
|
|
2023-03-25 00:48:14 +02:00
|
|
|
bool isCastingPossibleHere (const CSpell * spell, const CStack *sactive, const CStack *shere, BattleHex myNumber);
|
2023-01-21 19:42:44 +02:00
|
|
|
bool canStackMoveHere (const CStack *sactive, BattleHex MyNumber) const; //TODO: move to BattleState / callback
|
|
|
|
std::vector<PossiblePlayerBattleAction> getPossibleActionsForStack (const CStack *stack) const; //called when stack gets its turn
|
|
|
|
void reorderPossibleActionsPriority(const CStack * stack, MouseHoveredHexContext context);
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
bool actionIsLegal(PossiblePlayerBattleAction action, BattleHex hoveredHex);
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
void actionSetCursor(PossiblePlayerBattleAction action, BattleHex hoveredHex);
|
|
|
|
void actionSetCursorBlocked(PossiblePlayerBattleAction action, BattleHex hoveredHex);
|
2022-11-20 22:56:42 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
std::string actionGetStatusMessage(PossiblePlayerBattleAction action, BattleHex hoveredHex);
|
|
|
|
std::string actionGetStatusMessageBlocked(PossiblePlayerBattleAction action, BattleHex hoveredHex);
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
void actionRealize(PossiblePlayerBattleAction action, BattleHex hoveredHex);
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
PossiblePlayerBattleAction selectAction(BattleHex myNumber);
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-01-29 14:27:57 +02:00
|
|
|
const CStack * getStackForHex(BattleHex myNumber) ;
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// attempts to initialize spellcasting action for stack
|
|
|
|
/// will silently return if stack is not a spellcaster
|
|
|
|
void tryActivateStackSpellcasting(const CStack *casterStack);
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-01-29 14:27:57 +02:00
|
|
|
/// returns spell that is currently being cast by hero or nullptr if none
|
|
|
|
const CSpell * getHeroSpellToCast() const;
|
|
|
|
|
|
|
|
/// if current stack is spellcaster, returns spell being cast, or null othervice
|
2023-03-25 00:48:14 +02:00
|
|
|
const CSpell * getStackSpellToCast(BattleHex hoveredHex);
|
2023-01-29 14:27:57 +02:00
|
|
|
|
|
|
|
/// returns true if current stack is a spellcaster
|
|
|
|
bool isActiveStackSpellcaster() const;
|
|
|
|
|
2022-11-20 22:56:42 +02:00
|
|
|
public:
|
2022-12-13 13:58:16 +02:00
|
|
|
BattleActionsController(BattleInterface & owner);
|
2022-11-20 22:56:42 +02:00
|
|
|
|
2022-12-11 23:16:23 +02:00
|
|
|
/// initialize list of potential actions for new active stack
|
2022-11-20 22:56:42 +02:00
|
|
|
void activateStack();
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// returns true if UI is currently in target selection mode
|
|
|
|
bool spellcastingModeActive() const;
|
|
|
|
|
2023-01-29 14:27:57 +02:00
|
|
|
/// returns true if one of the following is true:
|
|
|
|
/// - we are casting spell by hero
|
|
|
|
/// - we are casting spell by creature in targeted mode (F hotkey)
|
|
|
|
/// - current creature is spellcaster and preferred action for current hex is spellcast
|
|
|
|
bool currentActionSpellcasting(BattleHex hoveredHex);
|
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// enter targeted spellcasting mode for creature, e.g. via "F" hotkey
|
2022-11-20 22:56:42 +02:00
|
|
|
void enterCreatureCastingMode();
|
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// initialize hero spellcasting mode, e.g. on selecting spell in spellbook
|
2022-12-11 23:16:23 +02:00
|
|
|
void castThisSpell(SpellID spellID);
|
|
|
|
|
|
|
|
/// ends casting spell (eg. when spell has been cast or canceled)
|
|
|
|
void endCastingSpell();
|
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// update cursor and status bar according to new active hex
|
|
|
|
void onHexHovered(BattleHex hoveredHex);
|
2022-11-20 22:56:42 +02:00
|
|
|
|
2023-01-29 17:52:19 +02:00
|
|
|
/// called when cursor is no longer over battlefield and cursor/battle log should be reset
|
|
|
|
void onHoverEnded();
|
|
|
|
|
|
|
|
/// performs action according to selected hex
|
|
|
|
void onHexLeftClicked(BattleHex clickedHex);
|
|
|
|
|
2023-01-21 19:42:44 +02:00
|
|
|
/// performs action according to selected hex
|
2023-01-29 17:52:19 +02:00
|
|
|
void onHexRightClicked(BattleHex clickedHex);
|
2023-01-21 19:42:44 +02:00
|
|
|
|
2023-01-29 14:27:57 +02:00
|
|
|
const spells::Caster * getCurrentSpellcaster() const;
|
2023-03-25 00:48:14 +02:00
|
|
|
const CSpell * getCurrentSpell(BattleHex hoveredHex);
|
2023-01-29 14:27:57 +02:00
|
|
|
spells::Mode getCurrentCastMode() const;
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2022-12-20 01:28:20 +02:00
|
|
|
/// methods to work with array of possible actions, needed to control special creatures abilities
|
|
|
|
const std::vector<PossiblePlayerBattleAction> & getPossibleActions() const;
|
|
|
|
void removePossibleAction(PossiblePlayerBattleAction);
|
|
|
|
|
|
|
|
/// inserts possible action in the beggining in order to prioritize it
|
|
|
|
void pushFrontPossibleAction(PossiblePlayerBattleAction);
|
2022-12-11 23:16:23 +02:00
|
|
|
|
2023-04-06 23:27:03 +02:00
|
|
|
void setTouchScreenMode(bool enabled);
|
2022-11-20 22:56:42 +02:00
|
|
|
};
|