2012-08-11 17:30:55 +02:00
|
|
|
#ifndef GAME_MWBASE_MECHANICSMANAGER_H
|
|
|
|
#define GAME_MWBASE_MECHANICSMANAGER_H
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2014-01-12 14:02:15 +01:00
|
|
|
#include <list>
|
2014-06-13 01:24:58 +02:00
|
|
|
#include <stdint.h>
|
2012-08-11 17:30:55 +02:00
|
|
|
|
|
|
|
namespace Ogre
|
|
|
|
{
|
|
|
|
class Vector3;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
struct Class;
|
2014-06-13 01:24:58 +02:00
|
|
|
|
|
|
|
class ESMReader;
|
|
|
|
class ESMWriter;
|
2012-08-11 17:30:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
class Ptr;
|
|
|
|
class CellStore;
|
|
|
|
}
|
|
|
|
|
2014-06-13 01:24:58 +02:00
|
|
|
namespace Loading
|
|
|
|
{
|
|
|
|
class Listener;
|
|
|
|
}
|
|
|
|
|
2012-08-11 17:30:55 +02:00
|
|
|
namespace MWBase
|
|
|
|
{
|
|
|
|
/// \brief Interface for game mechanics manager (implemented in MWMechanics)
|
|
|
|
class MechanicsManager
|
|
|
|
{
|
|
|
|
MechanicsManager (const MechanicsManager&);
|
|
|
|
///< not implemented
|
|
|
|
|
|
|
|
MechanicsManager& operator= (const MechanicsManager&);
|
|
|
|
///< not implemented
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
MechanicsManager() {}
|
|
|
|
|
|
|
|
virtual ~MechanicsManager() {}
|
|
|
|
|
2013-01-28 23:39:11 -08:00
|
|
|
virtual void add (const MWWorld::Ptr& ptr) = 0;
|
|
|
|
///< Register an object for management
|
2012-08-11 17:30:55 +02:00
|
|
|
|
2013-01-28 23:39:11 -08:00
|
|
|
virtual void remove (const MWWorld::Ptr& ptr) = 0;
|
|
|
|
///< Deregister an object for management
|
2012-08-11 17:30:55 +02:00
|
|
|
|
2013-02-25 09:57:34 -08:00
|
|
|
virtual void updateCell(const MWWorld::Ptr &old, const MWWorld::Ptr &ptr) = 0;
|
2013-01-29 00:19:24 -08:00
|
|
|
///< Moves an object to a new cell
|
|
|
|
|
2013-01-28 23:39:11 -08:00
|
|
|
virtual void drop (const MWWorld::CellStore *cellStore) = 0;
|
|
|
|
///< Deregister all objects in the given cell.
|
2012-08-11 17:30:55 +02:00
|
|
|
|
|
|
|
virtual void watchActor (const MWWorld::Ptr& ptr) = 0;
|
|
|
|
///< On each update look for changes in a previously registered actor and update the
|
|
|
|
/// GUI accordingly.
|
|
|
|
|
2013-01-16 08:22:38 -08:00
|
|
|
virtual void update (float duration, bool paused) = 0;
|
2013-01-28 23:39:11 -08:00
|
|
|
///< Update objects
|
2012-08-11 17:30:55 +02:00
|
|
|
///
|
|
|
|
/// \param paused In game type does not currently advance (this usually means some GUI
|
|
|
|
/// component is up).
|
|
|
|
|
2013-11-19 16:42:24 +01:00
|
|
|
virtual void advanceTime (float duration) = 0;
|
|
|
|
|
2012-08-11 17:30:55 +02:00
|
|
|
virtual void setPlayerName (const std::string& name) = 0;
|
|
|
|
///< Set player name.
|
|
|
|
|
2012-11-10 11:41:12 +04:00
|
|
|
virtual void setPlayerRace (const std::string& id, bool male, const std::string &head, const std::string &hair) = 0;
|
2012-08-11 17:30:55 +02:00
|
|
|
///< Set player race.
|
|
|
|
|
|
|
|
virtual void setPlayerBirthsign (const std::string& id) = 0;
|
|
|
|
///< Set player birthsign.
|
|
|
|
|
|
|
|
virtual void setPlayerClass (const std::string& id) = 0;
|
|
|
|
///< Set player class to stock class.
|
|
|
|
|
|
|
|
virtual void setPlayerClass (const ESM::Class& class_) = 0;
|
|
|
|
///< Set player class to custom class.
|
2012-09-21 17:53:16 +02:00
|
|
|
|
2014-01-14 02:20:13 +01:00
|
|
|
virtual void rest(bool sleep) = 0;
|
|
|
|
///< If the player is sleeping or waiting, this should be called every hour.
|
|
|
|
/// @param sleep is the player sleeping or waiting?
|
2012-11-05 11:07:43 +01:00
|
|
|
|
2014-01-14 02:52:34 +01:00
|
|
|
virtual int getHoursToRest() const = 0;
|
|
|
|
///< Calculate how many hours the player needs to rest in order to be fully healed
|
|
|
|
|
2012-11-09 14:42:09 +01:00
|
|
|
virtual int getBarterOffer(const MWWorld::Ptr& ptr,int basePrice, bool buying) = 0;
|
2012-11-05 11:07:43 +01:00
|
|
|
///< This is used by every service to determine the price of objects given the trading skills of the player and NPC.
|
|
|
|
|
2012-11-09 14:42:09 +01:00
|
|
|
virtual int getDerivedDisposition(const MWWorld::Ptr& ptr) = 0;
|
2012-11-05 11:07:43 +01:00
|
|
|
///< Calculate the diposition of an NPC toward the player.
|
2013-03-16 22:53:33 +01:00
|
|
|
|
2012-10-27 11:33:18 +02:00
|
|
|
virtual int countDeaths (const std::string& id) const = 0;
|
|
|
|
///< Return the number of deaths for actors with the given ID.
|
2012-11-09 20:18:38 +01:00
|
|
|
|
2014-01-07 00:51:09 +01:00
|
|
|
/// Check if \a observer is potentially aware of \a ptr. Does not do a line of sight check!
|
|
|
|
virtual bool awarenessCheck (const MWWorld::Ptr& ptr, const MWWorld::Ptr& observer) = 0;
|
|
|
|
|
2014-05-06 00:13:31 +02:00
|
|
|
/// Makes \a ptr fight \a target. Also shouts a combat taunt.
|
|
|
|
virtual void startCombat (const MWWorld::Ptr& ptr, const MWWorld::Ptr& target) = 0;
|
|
|
|
|
2014-01-07 19:49:16 +01:00
|
|
|
enum OffenseType
|
|
|
|
{
|
|
|
|
OT_Theft, // Taking items owned by an NPC or a faction you are not a member of
|
|
|
|
OT_Assault, // Attacking a peaceful NPC
|
|
|
|
OT_Murder, // Murdering a peaceful NPC
|
|
|
|
OT_Trespassing, // Staying in a cell you are not allowed in (where is this defined?)
|
|
|
|
OT_SleepingInOwnedBed, // Sleeping in a bed owned by an NPC or a faction you are not a member of
|
|
|
|
OT_Pickpocket // Entering pickpocket mode, leaving it, and being detected. Any items stolen are a separate crime (Theft)
|
|
|
|
};
|
|
|
|
/**
|
|
|
|
* @brief Commit a crime. If any actors witness the crime and report it,
|
|
|
|
* reportCrime will be called automatically.
|
2014-06-17 01:10:37 +02:00
|
|
|
* @note victim may be empty
|
2014-01-07 19:49:16 +01:00
|
|
|
* @param arg Depends on \a type, e.g. for Theft, the value of the item that was stolen.
|
2014-01-08 17:19:43 +01:00
|
|
|
* @return was the crime reported?
|
2014-01-07 19:49:16 +01:00
|
|
|
*/
|
2014-01-08 17:19:43 +01:00
|
|
|
virtual bool commitCrime (const MWWorld::Ptr& ptr, const MWWorld::Ptr& victim,
|
2014-01-07 19:49:16 +01:00
|
|
|
OffenseType type, int arg=0) = 0;
|
|
|
|
virtual void reportCrime (const MWWorld::Ptr& ptr, const MWWorld::Ptr& victim,
|
|
|
|
OffenseType type, int arg=0) = 0;
|
2014-09-26 22:08:07 +02:00
|
|
|
/// @return false if the attack was considered a "friendly hit" and forgiven
|
|
|
|
virtual bool actorAttacked (const MWWorld::Ptr& victim, const MWWorld::Ptr& attacker) = 0;
|
2014-01-07 19:49:16 +01:00
|
|
|
/// Utility to check if taking this item is illegal and calling commitCrime if so
|
|
|
|
virtual void itemTaken (const MWWorld::Ptr& ptr, const MWWorld::Ptr& item, int count) = 0;
|
2014-01-10 21:26:24 +01:00
|
|
|
/// Utility to check if opening (i.e. unlocking) this object is illegal and calling commitCrime if so
|
|
|
|
virtual void objectOpened (const MWWorld::Ptr& ptr, const MWWorld::Ptr& item) = 0;
|
2014-01-08 17:19:43 +01:00
|
|
|
/// Attempt sleeping in a bed. If this is illegal, call commitCrime.
|
|
|
|
/// @return was it illegal, and someone saw you doing it?
|
|
|
|
virtual bool sleepInBed (const MWWorld::Ptr& ptr, const MWWorld::Ptr& bed) = 0;
|
2014-01-07 19:49:16 +01:00
|
|
|
|
2014-09-22 15:18:19 +02:00
|
|
|
/// @return is \a ptr allowed to take/use \a item or is it a crime?
|
|
|
|
virtual bool isAllowedToUse (const MWWorld::Ptr& ptr, const MWWorld::Ptr& item, MWWorld::Ptr& victim) = 0;
|
|
|
|
|
2012-11-09 20:18:38 +01:00
|
|
|
enum PersuasionType
|
|
|
|
{
|
|
|
|
PT_Admire,
|
|
|
|
PT_Intimidate,
|
|
|
|
PT_Taunt,
|
|
|
|
PT_Bribe10,
|
|
|
|
PT_Bribe100,
|
|
|
|
PT_Bribe1000
|
|
|
|
};
|
2012-11-10 00:29:36 +01:00
|
|
|
virtual void getPersuasionDispositionChange (const MWWorld::Ptr& npc, PersuasionType type,
|
|
|
|
float currentTemporaryDispositionDelta, bool& success, float& tempChange, float& permChange) = 0;
|
|
|
|
///< Perform a persuasion action on NPC
|
2013-01-16 17:53:18 -08:00
|
|
|
|
2013-12-07 13:17:28 +01:00
|
|
|
virtual void forceStateUpdate(const MWWorld::Ptr &ptr) = 0;
|
|
|
|
///< Forces an object to refresh its animation state.
|
2013-04-25 07:08:11 -07:00
|
|
|
|
2013-12-07 13:17:28 +01:00
|
|
|
virtual void playAnimationGroup(const MWWorld::Ptr& ptr, const std::string& groupName, int mode, int number=1) = 0;
|
|
|
|
///< Run animation for a MW-reference. Calls to this function for references that are currently not
|
|
|
|
/// in the scene should be ignored.
|
|
|
|
///
|
|
|
|
/// \param mode 0 normal, 1 immediate start, 2 immediate loop
|
|
|
|
/// \param count How many times the animation should be run
|
2013-01-16 17:53:18 -08:00
|
|
|
|
2013-12-07 13:17:28 +01:00
|
|
|
virtual void skipAnimation(const MWWorld::Ptr& ptr) = 0;
|
|
|
|
///< Skip the animation for the given MW-reference for one frame. Calls to this function for
|
|
|
|
/// references that are currently not in the scene should be ignored.
|
2013-05-24 20:10:07 -07:00
|
|
|
|
2013-12-07 13:17:28 +01:00
|
|
|
virtual bool checkAnimationPlaying(const MWWorld::Ptr& ptr, const std::string& groupName) = 0;
|
2013-11-17 23:15:57 +01:00
|
|
|
|
2013-12-07 13:17:28 +01:00
|
|
|
/// Update magic effects for an actor. Usually done automatically once per frame, but if we're currently
|
|
|
|
/// paused we may want to do it manually (after equipping permanent enchantment)
|
|
|
|
virtual void updateMagicEffects (const MWWorld::Ptr& ptr) = 0;
|
2013-11-17 23:15:57 +01:00
|
|
|
|
2014-03-26 19:55:52 +01:00
|
|
|
virtual bool toggleAI() = 0;
|
2013-12-07 13:17:28 +01:00
|
|
|
virtual bool isAIActive() = 0;
|
2014-01-20 13:00:43 +01:00
|
|
|
|
|
|
|
virtual void getObjectsInRange (const Ogre::Vector3& position, float radius, std::vector<MWWorld::Ptr>& objects) = 0;
|
2014-04-24 22:41:05 -04:00
|
|
|
virtual void getActorsInRange(const Ogre::Vector3 &position, float radius, std::vector<MWWorld::Ptr> &objects) = 0;
|
2014-01-28 12:33:31 +01:00
|
|
|
|
2014-04-24 22:47:45 -04:00
|
|
|
///return the list of actors which are following the given actor
|
|
|
|
/**ie AiFollow is active and the target is the actor**/
|
2014-01-28 12:33:31 +01:00
|
|
|
virtual std::list<MWWorld::Ptr> getActorsFollowing(const MWWorld::Ptr& actor) = 0;
|
2014-12-09 16:02:07 +01:00
|
|
|
virtual std::list<int> getActorsFollowingIndices(const MWWorld::Ptr& actor) = 0;
|
2014-02-01 18:16:32 +01:00
|
|
|
|
2014-04-24 22:47:45 -04:00
|
|
|
///Returns a list of actors who are fighting the given actor within the fAlarmDistance
|
|
|
|
/** ie AiCombat is active and the target is the actor **/
|
|
|
|
virtual std::list<MWWorld::Ptr> getActorsFighting(const MWWorld::Ptr& actor) = 0;
|
|
|
|
|
2013-12-07 13:17:28 +01:00
|
|
|
virtual void playerLoaded() = 0;
|
2014-06-13 01:24:58 +02:00
|
|
|
|
|
|
|
virtual int countSavedGameRecords() const = 0;
|
|
|
|
|
|
|
|
virtual void write (ESM::ESMWriter& writer, Loading::Listener& listener) const = 0;
|
|
|
|
|
|
|
|
virtual void readRecord (ESM::ESMReader& reader, int32_t type) = 0;
|
|
|
|
|
|
|
|
virtual void clear() = 0;
|
2014-06-16 19:34:53 +02:00
|
|
|
|
2014-06-17 01:10:37 +02:00
|
|
|
/// @param bias Can be used to add an additional aggression bias towards the target,
|
|
|
|
/// making it more likely for the function to return true.
|
2014-06-17 17:04:41 +02:00
|
|
|
virtual bool isAggressive (const MWWorld::Ptr& ptr, const MWWorld::Ptr& target, int bias=0, bool ignoreDistance=false) = 0;
|
2014-07-21 20:37:14 +02:00
|
|
|
|
2014-09-05 17:17:45 +02:00
|
|
|
/// Resurrects the player if necessary
|
|
|
|
virtual void keepPlayerAlive() = 0;
|
2014-12-12 16:49:22 +01:00
|
|
|
|
|
|
|
virtual bool isReadyToBlock (const MWWorld::Ptr& ptr) const = 0;
|
2012-08-11 17:30:55 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|