2010-08-03 11:14:57 +02:00
|
|
|
#ifndef GAME_MWWORLD_CLASS_H
|
|
|
|
#define GAME_MWWORLD_CLASS_H
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
#include <string>
|
2012-03-13 13:45:50 +01:00
|
|
|
#include <vector>
|
2010-08-03 11:14:57 +02:00
|
|
|
|
|
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
|
2010-08-03 18:20:15 +02:00
|
|
|
#include "action.hpp"
|
2010-08-04 14:37:23 +02:00
|
|
|
#include "refdata.hpp"
|
2011-11-12 15:58:22 -05:00
|
|
|
#include "physicssystem.hpp"
|
2010-08-03 18:20:15 +02:00
|
|
|
|
2012-02-20 12:44:17 +01:00
|
|
|
#include "../mwrender/renderinginterface.hpp"
|
|
|
|
|
2011-02-03 11:37:17 +01:00
|
|
|
namespace Ogre
|
|
|
|
{
|
|
|
|
class Vector3;
|
|
|
|
}
|
|
|
|
|
2010-08-14 09:20:47 +02:00
|
|
|
namespace MWRender
|
|
|
|
{
|
|
|
|
class CellRenderImp;
|
|
|
|
}
|
|
|
|
|
2010-08-03 11:49:12 +02:00
|
|
|
namespace MWMechanics
|
|
|
|
{
|
|
|
|
struct CreatureStats;
|
2010-08-19 12:49:13 +02:00
|
|
|
struct NpcStats;
|
2011-02-03 11:37:17 +01:00
|
|
|
struct Movement;
|
2010-08-03 11:49:12 +02:00
|
|
|
}
|
|
|
|
|
2010-08-03 11:14:57 +02:00
|
|
|
namespace MWWorld
|
|
|
|
{
|
2010-08-03 11:49:12 +02:00
|
|
|
class Ptr;
|
2010-08-14 09:20:47 +02:00
|
|
|
class Environment;
|
2012-02-20 12:44:17 +01:00
|
|
|
class ContainerStore;
|
2012-03-10 12:49:54 +01:00
|
|
|
class InventoryStore;
|
2010-08-03 11:49:12 +02:00
|
|
|
|
2010-08-03 11:14:57 +02:00
|
|
|
/// \brief Base class for referenceable esm records
|
|
|
|
class Class
|
|
|
|
{
|
|
|
|
static std::map<std::string, boost::shared_ptr<Class> > sClasses;
|
|
|
|
|
|
|
|
// not implemented
|
|
|
|
Class (const Class&);
|
|
|
|
Class& operator= (const Class&);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
Class();
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
2011-01-18 10:45:29 +01:00
|
|
|
/// NPC-stances.
|
|
|
|
enum Stance
|
|
|
|
{
|
|
|
|
Run, Sneak, Combat
|
|
|
|
};
|
|
|
|
|
2010-08-03 11:14:57 +02:00
|
|
|
virtual ~Class();
|
|
|
|
|
2010-08-08 14:28:35 +02:00
|
|
|
virtual std::string getId (const Ptr& ptr) const;
|
|
|
|
///< Return ID of \a ptr or throw an exception, if class does not support ID retrieval
|
|
|
|
/// (default implementation: throw an exception)
|
|
|
|
|
2011-11-09 15:47:06 -05:00
|
|
|
virtual void insertObjectRendering (const Ptr& ptr, MWRender::RenderingInterface& renderingInterface) const;
|
2011-11-11 00:20:53 -05:00
|
|
|
virtual void insertObject(const Ptr& ptr, MWWorld::PhysicsSystem& physics, MWWorld::Environment& environment) const;
|
2010-08-14 09:20:47 +02:00
|
|
|
///< Add reference into a cell for rendering (default implementation: don't render anything).
|
|
|
|
|
2010-08-14 11:27:13 +02:00
|
|
|
virtual void enable (const Ptr& ptr, MWWorld::Environment& environment) const;
|
|
|
|
///< Enable reference; only does the non-rendering part (default implementation: ignore)
|
|
|
|
/// \attention This is not the same as the script instruction with the same name. References
|
|
|
|
/// should only be enabled while in an active cell.
|
|
|
|
|
|
|
|
virtual void disable (const Ptr& ptr, MWWorld::Environment& environment) const;
|
|
|
|
///< Enable reference; only does the non-rendering part (default implementation: ignore)
|
|
|
|
/// \attention This is not the same as the script instruction with the same name. References
|
|
|
|
/// should only be enabled while in an active cell.
|
|
|
|
|
2010-08-03 17:11:41 +02:00
|
|
|
virtual std::string getName (const Ptr& ptr) const = 0;
|
|
|
|
///< \return name (the one that is to be presented to the user; not the internal one);
|
|
|
|
/// can return an empty string.
|
|
|
|
|
2010-08-03 11:49:12 +02:00
|
|
|
virtual MWMechanics::CreatureStats& getCreatureStats (const Ptr& ptr) const;
|
|
|
|
///< Return creature stats or throw an exception, if class does not have creature stats
|
|
|
|
/// (default implementation: throw an exceoption)
|
2010-08-03 11:14:57 +02:00
|
|
|
|
2010-08-19 12:49:13 +02:00
|
|
|
virtual MWMechanics::NpcStats& getNpcStats (const Ptr& ptr) const;
|
|
|
|
///< Return NPC stats or throw an exception, if class does not have NPC stats
|
|
|
|
/// (default implementation: throw an exceoption)
|
|
|
|
|
2010-08-03 14:14:04 +02:00
|
|
|
virtual bool hasItemHealth (const Ptr& ptr) const;
|
|
|
|
///< \return Item health data available? (default implementation: false)
|
|
|
|
|
|
|
|
virtual int getItemMaxHealth (const Ptr& ptr) const;
|
|
|
|
///< Return item max health or throw an exception, if class does not have item health
|
|
|
|
/// (default implementation: throw an exceoption)
|
2010-08-03 11:14:57 +02:00
|
|
|
|
2010-08-03 18:44:52 +02:00
|
|
|
virtual boost::shared_ptr<Action> activate (const Ptr& ptr, const Ptr& actor,
|
|
|
|
const Environment& environment) const;
|
2010-08-03 18:20:15 +02:00
|
|
|
///< Generate action for activation (default implementation: return a null action).
|
|
|
|
|
2010-08-03 18:44:52 +02:00
|
|
|
virtual boost::shared_ptr<Action> use (const Ptr& ptr, const Environment& environment)
|
|
|
|
const;
|
2010-08-03 18:20:15 +02:00
|
|
|
///< Generate action for using via inventory menu (default implementation: return a
|
|
|
|
/// null action).
|
|
|
|
|
2012-01-28 11:45:55 +01:00
|
|
|
virtual ContainerStore& getContainerStore (const Ptr& ptr) const;
|
2010-08-04 14:37:23 +02:00
|
|
|
///< Return container store or throw an exception, if class does not have a
|
|
|
|
/// container store (default implementation: throw an exceoption)
|
|
|
|
|
2012-03-10 12:49:54 +01:00
|
|
|
virtual InventoryStore& getInventoryStore (const Ptr& ptr) const;
|
|
|
|
///< Return inventory store or throw an exception, if class does not have a
|
|
|
|
/// inventory store (default implementation: throw an exceoption)
|
|
|
|
|
2010-08-30 11:56:55 +02:00
|
|
|
virtual void lock (const Ptr& ptr, int lockLevel) const;
|
|
|
|
///< Lock object (default implementation: throw an exception)
|
|
|
|
|
|
|
|
virtual void unlock (const Ptr& ptr) const;
|
|
|
|
///< Unlock object (default implementation: throw an exception)
|
|
|
|
|
2010-08-05 15:40:03 +02:00
|
|
|
virtual std::string getScript (const Ptr& ptr) const;
|
|
|
|
///< Return name of the script attached to ptr (default implementation: return an empty
|
|
|
|
/// string).
|
|
|
|
|
2011-01-18 10:45:29 +01:00
|
|
|
virtual void setForceStance (const Ptr& ptr, Stance stance, bool force) const;
|
|
|
|
///< Force or unforce a stance.
|
|
|
|
|
|
|
|
virtual void setStance (const Ptr& ptr, Stance stance, bool set) const;
|
|
|
|
///< Set or unset a stance.
|
|
|
|
|
|
|
|
virtual bool getStance (const Ptr& ptr, Stance stance, bool ignoreForce = false) const;
|
|
|
|
////< Check if a stance is active or not.
|
|
|
|
|
|
|
|
virtual float getSpeed (const Ptr& ptr) const;
|
|
|
|
///< Return movement speed.
|
|
|
|
|
2011-02-03 11:37:17 +01:00
|
|
|
virtual MWMechanics::Movement& getMovementSettings (const Ptr& ptr) const;
|
|
|
|
///< Return desired movement.
|
|
|
|
|
|
|
|
virtual Ogre::Vector3 getMovementVector (const Ptr& ptr) const;
|
|
|
|
///< Return desired movement vector (determined based on movement settings,
|
|
|
|
/// stance and stats).
|
|
|
|
|
2012-03-13 14:12:07 +01:00
|
|
|
virtual std::pair<std::vector<int>, bool> getEquipmentSlots (const Ptr& ptr) const;
|
2012-03-13 13:45:50 +01:00
|
|
|
///< \return first: Return IDs of the slot this object can be equipped in; second: can object
|
|
|
|
/// stay stacked when equipped?
|
|
|
|
///
|
|
|
|
/// Default implementation: return (empty vector, false).
|
|
|
|
|
2012-03-15 14:31:16 +01:00
|
|
|
virtual int getEquipmentSkill (const Ptr& ptr, const Environment& environment)
|
2012-03-13 14:12:07 +01:00
|
|
|
const;
|
|
|
|
/// Return the index of the skill this item corresponds to when equiopped or -1, if there is
|
|
|
|
/// no such skill.
|
|
|
|
/// (default implementation: return -1)
|
|
|
|
|
2010-08-03 11:14:57 +02:00
|
|
|
static const Class& get (const std::string& key);
|
|
|
|
///< If there is no class for this \a key, an exception is thrown.
|
|
|
|
|
2010-08-03 11:49:12 +02:00
|
|
|
static const Class& get (const Ptr& ptr);
|
|
|
|
///< If there is no class for this pointer, an exception is thrown.
|
|
|
|
|
2010-08-03 11:14:57 +02:00
|
|
|
static void registerClass (const std::string& key, boost::shared_ptr<Class> instance);
|
2012-03-13 18:05:38 +02:00
|
|
|
|
2012-03-14 00:38:44 +02:00
|
|
|
virtual std::string getUpSoundId (const Ptr& ptr, const MWWorld::Environment& environment) const;
|
2012-03-13 18:05:38 +02:00
|
|
|
///< Return the up sound ID of \a ptr or throw an exception, if class does not support ID retrieval
|
|
|
|
/// (default implementation: throw an exception)
|
|
|
|
|
2012-03-14 00:38:44 +02:00
|
|
|
virtual std::string getDownSoundId (const Ptr& ptr, const MWWorld::Environment& environment) const;
|
2012-03-13 18:05:38 +02:00
|
|
|
///< Return the down sound ID of \a ptr or throw an exception, if class does not support ID retrieval
|
|
|
|
/// (default implementation: throw an exception)
|
2010-08-03 11:14:57 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|