2012-08-11 15:30:55 +00:00
|
|
|
#ifndef GAME_MWMECHANICS_MECHANICSMANAGERIMP_H
|
|
|
|
#define GAME_MWMECHANICS_MECHANICSMANAGERIMP_H
|
2010-07-26 09:15:38 +00:00
|
|
|
|
2012-08-11 15:30:55 +00:00
|
|
|
#include "../mwbase/mechanicsmanager.hpp"
|
2010-07-27 12:05:05 +00:00
|
|
|
|
|
|
|
#include "../mwworld/ptr.hpp"
|
|
|
|
|
2010-07-27 13:59:41 +00:00
|
|
|
#include "creaturestats.hpp"
|
2010-09-21 15:42:07 +00:00
|
|
|
#include "npcstats.hpp"
|
2013-03-31 22:29:41 +00:00
|
|
|
#include "objects.hpp"
|
2012-03-30 14:18:58 +00:00
|
|
|
#include "actors.hpp"
|
2010-07-27 13:59:41 +00:00
|
|
|
|
2011-02-01 09:11:41 +00:00
|
|
|
namespace Ogre
|
|
|
|
{
|
|
|
|
class Vector3;
|
|
|
|
}
|
|
|
|
|
2012-07-03 11:55:53 +00:00
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
class CellStore;
|
|
|
|
}
|
|
|
|
|
2010-07-26 09:15:38 +00:00
|
|
|
namespace MWMechanics
|
|
|
|
{
|
2012-08-11 15:30:55 +00:00
|
|
|
class MechanicsManager : public MWBase::MechanicsManager
|
2010-07-26 09:15:38 +00:00
|
|
|
{
|
2010-07-27 13:59:41 +00:00
|
|
|
MWWorld::Ptr mWatched;
|
2013-08-28 00:56:47 +00:00
|
|
|
NpcStats mWatchedStats;
|
2014-09-13 00:56:06 +00:00
|
|
|
bool mWatchedStatsEmpty;
|
2010-09-15 12:33:02 +00:00
|
|
|
bool mUpdatePlayer;
|
2010-09-26 08:01:30 +00:00
|
|
|
bool mClassSelected;
|
|
|
|
bool mRaceSelected;
|
2013-11-18 22:03:44 +00:00
|
|
|
bool mAI;///< is AI active?
|
2013-01-29 07:39:11 +00:00
|
|
|
|
2013-03-31 22:29:41 +00:00
|
|
|
Objects mObjects;
|
2012-03-30 14:18:58 +00:00
|
|
|
Actors mActors;
|
2010-09-13 20:59:28 +00:00
|
|
|
|
2013-11-14 13:41:10 +00:00
|
|
|
public:
|
|
|
|
|
2010-09-15 11:31:26 +00:00
|
|
|
void buildPlayer();
|
|
|
|
///< build player according to stored class/race/birthsign information. Will
|
|
|
|
/// default to the values of the ESM::NPC object, if no explicit information is given.
|
|
|
|
|
2012-08-11 15:30:55 +00:00
|
|
|
MechanicsManager();
|
2010-09-13 20:59:28 +00:00
|
|
|
|
2013-01-29 07:39:11 +00:00
|
|
|
virtual void add (const MWWorld::Ptr& ptr);
|
|
|
|
///< Register an object for management
|
2010-07-27 12:43:46 +00:00
|
|
|
|
2013-01-29 07:39:11 +00:00
|
|
|
virtual void remove (const MWWorld::Ptr& ptr);
|
|
|
|
///< Deregister an object for management
|
2010-09-13 20:59:28 +00:00
|
|
|
|
2013-02-25 17:57:34 +00:00
|
|
|
virtual void updateCell(const MWWorld::Ptr &old, const MWWorld::Ptr &ptr);
|
2013-01-29 08:19:24 +00:00
|
|
|
///< Moves an object to a new cell
|
|
|
|
|
2013-01-29 07:39:11 +00:00
|
|
|
virtual void drop(const MWWorld::CellStore *cellStore);
|
|
|
|
///< Deregister all objects in the given cell.
|
2010-09-13 20:59:28 +00:00
|
|
|
|
2013-01-29 07:39:11 +00:00
|
|
|
virtual void watchActor(const MWWorld::Ptr& ptr);
|
2010-07-27 13:59:41 +00:00
|
|
|
///< On each update look for changes in a previously registered actor and update the
|
|
|
|
/// GUI accordingly.
|
2010-09-13 20:59:28 +00:00
|
|
|
|
2013-01-16 16:22:38 +00:00
|
|
|
virtual void update (float duration, bool paused);
|
2013-01-29 07:39:11 +00:00
|
|
|
///< Update objects
|
2012-03-30 15:01:55 +00:00
|
|
|
///
|
|
|
|
/// \param paused In game type does not currently advance (this usually means some GUI
|
|
|
|
/// component is up).
|
2010-09-13 20:59:28 +00:00
|
|
|
|
2013-11-19 15:42:24 +00:00
|
|
|
virtual void advanceTime (float duration);
|
|
|
|
|
2012-08-11 15:30:55 +00:00
|
|
|
virtual void setPlayerName (const std::string& name);
|
2010-09-13 20:59:28 +00:00
|
|
|
///< Set player name.
|
|
|
|
|
2012-11-10 07:41:12 +00:00
|
|
|
virtual void setPlayerRace (const std::string& id, bool male, const std::string &head, const std::string &hair);
|
2010-09-13 20:59:28 +00:00
|
|
|
///< Set player race.
|
|
|
|
|
2012-08-11 15:30:55 +00:00
|
|
|
virtual void setPlayerBirthsign (const std::string& id);
|
2010-09-13 20:59:28 +00:00
|
|
|
///< Set player birthsign.
|
|
|
|
|
2012-08-11 15:30:55 +00:00
|
|
|
virtual void setPlayerClass (const std::string& id);
|
2010-09-13 20:59:28 +00:00
|
|
|
///< Set player class to stock class.
|
|
|
|
|
2012-08-11 15:30:55 +00:00
|
|
|
virtual void setPlayerClass (const ESM::Class& class_);
|
2010-09-13 20:59:28 +00:00
|
|
|
///< Set player class to custom class.
|
2012-09-21 15:53:16 +00:00
|
|
|
|
2014-01-14 01:20:13 +00:00
|
|
|
virtual void rest(bool sleep);
|
|
|
|
///< If the player is sleeping or waiting, this should be called every hour.
|
|
|
|
/// @param sleep is the player sleeping or waiting?
|
2012-11-05 10:07:43 +00:00
|
|
|
|
2014-01-14 01:52:34 +00:00
|
|
|
virtual int getHoursToRest() const;
|
|
|
|
///< Calculate how many hours the player needs to rest in order to be fully healed
|
|
|
|
|
2012-11-09 13:42:09 +00:00
|
|
|
virtual int getBarterOffer(const MWWorld::Ptr& ptr,int basePrice, bool buying);
|
2012-11-05 10:07:43 +00: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 13:42:09 +00:00
|
|
|
virtual int getDerivedDisposition(const MWWorld::Ptr& ptr);
|
2012-11-05 10:07:43 +00:00
|
|
|
///< Calculate the diposition of an NPC toward the player.
|
2012-11-08 22:16:40 +00:00
|
|
|
|
2012-10-27 09:33:18 +00:00
|
|
|
virtual int countDeaths (const std::string& id) const;
|
|
|
|
///< Return the number of deaths for actors with the given ID.
|
2013-11-19 08:10:48 +00:00
|
|
|
|
2012-11-09 23:29:36 +00:00
|
|
|
virtual void getPersuasionDispositionChange (const MWWorld::Ptr& npc, PersuasionType type,
|
|
|
|
float currentTemporaryDispositionDelta, bool& success, float& tempChange, float& permChange);
|
2013-01-09 19:51:52 +00:00
|
|
|
void toLower(std::string npcFaction);
|
2012-11-09 23:29:36 +00:00
|
|
|
///< Perform a persuasion action on NPC
|
2013-01-17 01:53:18 +00:00
|
|
|
|
2014-01-06 23:51:09 +00: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);
|
|
|
|
|
2014-05-05 22:13:31 +00:00
|
|
|
/// Makes \a ptr fight \a target. Also shouts a combat taunt.
|
|
|
|
virtual void startCombat (const MWWorld::Ptr& ptr, const MWWorld::Ptr& target);
|
|
|
|
|
2014-01-07 18:49:16 +00:00
|
|
|
/**
|
|
|
|
* @brief Commit a crime. If any actors witness the crime and report it,
|
|
|
|
* reportCrime will be called automatically.
|
2014-06-16 02:03:53 +00:00
|
|
|
* @note victim may be empty
|
2014-01-07 18:49:16 +00:00
|
|
|
* @param arg Depends on \a type, e.g. for Theft, the value of the item that was stolen.
|
2014-01-08 16:19:43 +00:00
|
|
|
* @return was the crime reported?
|
2014-01-07 18:49:16 +00:00
|
|
|
*/
|
2014-01-08 16:19:43 +00:00
|
|
|
virtual bool commitCrime (const MWWorld::Ptr& ptr, const MWWorld::Ptr& victim,
|
2014-01-07 18:49:16 +00:00
|
|
|
OffenseType type, int arg=0);
|
|
|
|
virtual void reportCrime (const MWWorld::Ptr& ptr, const MWWorld::Ptr& victim,
|
|
|
|
OffenseType type, int arg=0);
|
2014-09-26 20:08:07 +00:00
|
|
|
/// @return false if the attack was considered a "friendly hit" and forgiven
|
|
|
|
virtual bool actorAttacked (const MWWorld::Ptr& victim, const MWWorld::Ptr& attacker);
|
2014-01-07 18:49:16 +00: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);
|
2014-01-10 20:26:24 +00: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);
|
2014-01-08 16:19:43 +00:00
|
|
|
/// Attempt sleeping in a bed. If this is illegal, call commitCrime.
|
2014-04-25 02:47:45 +00:00
|
|
|
/// @return was it illegal, and someone saw you doing it? Also returns fail when enemies are nearby
|
2014-01-08 16:19:43 +00:00
|
|
|
virtual bool sleepInBed (const MWWorld::Ptr& ptr, const MWWorld::Ptr& bed);
|
2014-01-07 18:49:16 +00:00
|
|
|
|
2013-12-07 12:17:28 +00:00
|
|
|
virtual void forceStateUpdate(const MWWorld::Ptr &ptr);
|
2013-04-25 14:08:11 +00:00
|
|
|
|
2013-12-07 12:17:28 +00:00
|
|
|
virtual void playAnimationGroup(const MWWorld::Ptr& ptr, const std::string& groupName, int mode, int number);
|
|
|
|
virtual void skipAnimation(const MWWorld::Ptr& ptr);
|
|
|
|
virtual bool checkAnimationPlaying(const MWWorld::Ptr& ptr, const std::string &groupName);
|
2013-11-17 22:15:57 +00: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);
|
|
|
|
|
2014-02-01 17:16:32 +00:00
|
|
|
virtual void getObjectsInRange (const Ogre::Vector3& position, float radius, std::vector<MWWorld::Ptr>& objects);
|
2014-04-25 02:41:05 +00:00
|
|
|
virtual void getActorsInRange(const Ogre::Vector3 &position, float radius, std::vector<MWWorld::Ptr> &objects);
|
2014-01-20 12:00:43 +00:00
|
|
|
|
2014-02-01 17:16:32 +00:00
|
|
|
virtual std::list<MWWorld::Ptr> getActorsFollowing(const MWWorld::Ptr& actor);
|
2014-01-28 11:33:31 +00:00
|
|
|
|
2014-04-25 02:47:45 +00:00
|
|
|
virtual std::list<MWWorld::Ptr> getActorsFighting(const MWWorld::Ptr& actor);
|
|
|
|
|
2014-03-26 18:55:52 +00:00
|
|
|
virtual bool toggleAI();
|
2013-12-07 12:17:28 +00:00
|
|
|
virtual bool isAIActive();
|
|
|
|
|
|
|
|
virtual void playerLoaded();
|
2014-06-12 23:24:58 +00:00
|
|
|
|
|
|
|
virtual int countSavedGameRecords() const;
|
|
|
|
|
|
|
|
virtual void write (ESM::ESMWriter& writer, Loading::Listener& listener) const;
|
|
|
|
|
|
|
|
virtual void readRecord (ESM::ESMReader& reader, int32_t type);
|
|
|
|
|
|
|
|
virtual void clear();
|
2014-06-16 17:34:53 +00:00
|
|
|
|
2014-06-16 23:10:37 +00: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 15:04:41 +00:00
|
|
|
virtual bool isAggressive (const MWWorld::Ptr& ptr, const MWWorld::Ptr& target, int bias=0, bool ignoreDistance=false);
|
2014-07-21 18:37:14 +00:00
|
|
|
|
2014-09-05 15:17:45 +00:00
|
|
|
virtual void keepPlayerAlive();
|
2010-07-26 09:15:38 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|