2012-03-30 14:18:58 +00:00
|
|
|
#ifndef GAME_MWMECHANICS_ACTORS_H
|
|
|
|
#define GAME_MWMECHANICS_ACTORS_H
|
|
|
|
|
|
|
|
#include <set>
|
|
|
|
#include <vector>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
namespace Ogre
|
|
|
|
{
|
|
|
|
class Vector3;
|
|
|
|
}
|
|
|
|
|
2012-07-03 11:55:53 +00:00
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
class Ptr;
|
|
|
|
class CellStore;
|
|
|
|
}
|
|
|
|
|
2012-03-30 14:18:58 +00:00
|
|
|
namespace MWMechanics
|
|
|
|
{
|
|
|
|
class Actors
|
|
|
|
{
|
2012-03-30 15:01:55 +00:00
|
|
|
std::set<MWWorld::Ptr> mActors;
|
|
|
|
float mDuration;
|
|
|
|
|
|
|
|
void updateNpc (const MWWorld::Ptr& ptr, float duration, bool paused);
|
2012-03-30 14:18:58 +00:00
|
|
|
|
2012-05-17 11:21:49 +00:00
|
|
|
void adjustMagicEffects (const MWWorld::Ptr& creature);
|
|
|
|
|
2012-07-17 10:18:43 +00:00
|
|
|
void calculateDynamicStats (const MWWorld::Ptr& ptr);
|
|
|
|
|
2012-07-17 13:49:37 +00:00
|
|
|
void calculateCreatureStatModifiers (const MWWorld::Ptr& ptr);
|
|
|
|
|
2012-03-30 14:18:58 +00:00
|
|
|
public:
|
|
|
|
|
2012-04-23 13:27:03 +00:00
|
|
|
Actors();
|
2012-03-30 14:18:58 +00:00
|
|
|
|
|
|
|
void addActor (const MWWorld::Ptr& ptr);
|
|
|
|
///< Register an actor for stats management
|
|
|
|
|
|
|
|
void removeActor (const MWWorld::Ptr& ptr);
|
|
|
|
///< Deregister an actor for stats management
|
2012-05-24 11:21:52 +00:00
|
|
|
///
|
|
|
|
/// \note Ignored, if \a ptr is not a registered actor.
|
2012-03-30 14:18:58 +00:00
|
|
|
|
2012-07-03 11:55:53 +00:00
|
|
|
void dropActors (const MWWorld::CellStore *cellStore);
|
2012-03-30 14:18:58 +00:00
|
|
|
///< Deregister all actors in the given cell.
|
|
|
|
|
2012-03-30 15:01:55 +00:00
|
|
|
void update (std::vector<std::pair<std::string, Ogre::Vector3> >& movement,
|
|
|
|
float duration, bool paused);
|
2012-03-30 14:18:58 +00:00
|
|
|
///< Update actor stats and store desired velocity vectors in \a movement
|
2012-05-18 11:54:07 +00:00
|
|
|
|
|
|
|
void updateActor (const MWWorld::Ptr& ptr, float duration);
|
|
|
|
///< This function is normally called automatically during the update process, but it can
|
|
|
|
/// also be called explicitly at any time to force an update.
|
|
|
|
|
2012-03-30 14:18:58 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|