2010-08-03 09:14:57 +00:00
|
|
|
#ifndef GAME_MWWORLD_CLASS_H
|
|
|
|
#define GAME_MWWORLD_CLASS_H
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
#include <string>
|
2012-03-13 12:45:50 +00:00
|
|
|
#include <vector>
|
2010-08-03 09:14:57 +00:00
|
|
|
|
|
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
|
2010-08-03 16:20:15 +00:00
|
|
|
#include "action.hpp"
|
2012-02-20 11:44:17 +00:00
|
|
|
|
2011-02-03 10:37:17 +00:00
|
|
|
namespace Ogre
|
|
|
|
{
|
|
|
|
class Vector3;
|
|
|
|
}
|
|
|
|
|
2010-08-14 07:20:47 +00:00
|
|
|
namespace MWRender
|
|
|
|
{
|
2012-07-03 11:15:20 +00:00
|
|
|
class RenderingInterface;
|
2010-08-14 07:20:47 +00:00
|
|
|
}
|
|
|
|
|
2010-08-03 09:49:12 +00:00
|
|
|
namespace MWMechanics
|
|
|
|
{
|
2012-08-13 17:53:54 +00:00
|
|
|
class CreatureStats;
|
2012-07-06 16:25:16 +00:00
|
|
|
class NpcStats;
|
2011-02-03 10:37:17 +00:00
|
|
|
struct Movement;
|
2010-08-03 09:49:12 +00:00
|
|
|
}
|
|
|
|
|
2012-07-03 11:15:20 +00:00
|
|
|
namespace MWGui
|
|
|
|
{
|
|
|
|
struct ToolTipInfo;
|
|
|
|
}
|
|
|
|
|
2012-07-25 13:18:17 +00:00
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
struct Position;
|
|
|
|
}
|
|
|
|
|
2010-08-03 09:14:57 +00:00
|
|
|
namespace MWWorld
|
|
|
|
{
|
2010-08-03 09:49:12 +00:00
|
|
|
class Ptr;
|
2012-02-20 11:44:17 +00:00
|
|
|
class ContainerStore;
|
2012-03-10 11:49:54 +00:00
|
|
|
class InventoryStore;
|
2012-07-03 11:15:20 +00:00
|
|
|
class PhysicsSystem;
|
2012-07-25 13:18:17 +00:00
|
|
|
class CellStore;
|
2010-08-03 09:49:12 +00:00
|
|
|
|
2010-08-03 09:14:57 +00: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();
|
|
|
|
|
2012-07-26 12:14:11 +00:00
|
|
|
virtual Ptr copyToCellImpl(const Ptr &ptr, CellStore &cell) const;
|
2012-07-25 13:18:17 +00:00
|
|
|
|
2010-08-03 09:14:57 +00:00
|
|
|
public:
|
|
|
|
|
2011-01-18 09:45:29 +00:00
|
|
|
/// NPC-stances.
|
|
|
|
enum Stance
|
|
|
|
{
|
|
|
|
Run, Sneak, Combat
|
|
|
|
};
|
|
|
|
|
2010-08-03 09:14:57 +00:00
|
|
|
virtual ~Class();
|
|
|
|
|
2010-08-08 12:28:35 +00: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 20:47:06 +00:00
|
|
|
virtual void insertObjectRendering (const Ptr& ptr, MWRender::RenderingInterface& renderingInterface) const;
|
2012-04-23 13:27:03 +00:00
|
|
|
virtual void insertObject(const Ptr& ptr, MWWorld::PhysicsSystem& physics) const;
|
2010-08-14 07:20:47 +00:00
|
|
|
///< Add reference into a cell for rendering (default implementation: don't render anything).
|
|
|
|
|
2010-08-03 15:11:41 +00: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.
|
|
|
|
|
2013-04-03 21:55:57 +00:00
|
|
|
virtual void adjustPosition(const MWWorld::Ptr& ptr) const;
|
|
|
|
///< Adjust position to stand on ground. Must be called post model load
|
|
|
|
|
2010-08-03 09:49:12 +00: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 09:14:57 +00:00
|
|
|
|
2012-04-16 17:30:52 +00:00
|
|
|
virtual bool hasToolTip (const Ptr& ptr) const;
|
|
|
|
///< @return true if this object has a tooltip when focused (default implementation: false)
|
|
|
|
|
2012-04-24 00:02:03 +00:00
|
|
|
virtual MWGui::ToolTipInfo getToolTipInfo (const Ptr& ptr) const;
|
2012-04-16 17:30:52 +00:00
|
|
|
///< @return the content of the tool tip to be displayed. raises exception if the object has no tooltip.
|
|
|
|
|
2010-08-19 10:49:13 +00: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 12:14:04 +00: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)
|
2013-07-24 09:51:42 +00:00
|
|
|
|
2013-07-25 15:15:42 +00:00
|
|
|
virtual float getEvasion(const Ptr& ptr) const;
|
|
|
|
///< Gets the chance the given object can evade an attack
|
|
|
|
|
2013-07-25 07:30:01 +00:00
|
|
|
virtual void hit(const Ptr& ptr, int type=-1) const;
|
2013-07-24 09:51:42 +00:00
|
|
|
///< Execute a melee hit, using the current weapon. This will check the relevant skills
|
|
|
|
/// of the given attacker, and whoever is hit.
|
2013-07-25 07:30:01 +00:00
|
|
|
/// \param type - type of attack, one of the MWMechanics::CreatureStats::AttackType
|
|
|
|
/// enums. ignored for creature attacks.
|
2013-07-24 09:51:42 +00:00
|
|
|
/// (default implementation: throw an exceoption)
|
|
|
|
|
2013-07-26 10:21:54 +00:00
|
|
|
virtual void onHit(const Ptr& ptr, float damage, const Ptr &object, const Ptr &attacker, bool successful) const;
|
|
|
|
///< Alerts \a ptr that it's being hit for \a damage health by \a object (sword, arrow,
|
|
|
|
/// etc). \a attacker specifies the actor responsible for the attack, and \a successful
|
|
|
|
/// specifies if the hit is successful or not.
|
|
|
|
|
2013-07-24 09:51:42 +00:00
|
|
|
virtual void setActorHealth(const Ptr& ptr, float health, const Ptr& attacker=Ptr()) const;
|
|
|
|
///< Sets a new current health value for the actor, optionally specifying the object causing
|
|
|
|
/// the change. Use this instead of using CreatureStats directly as this will make sure the
|
|
|
|
/// correct dialog and actor states are properly handled when being hurt or healed.
|
|
|
|
/// (default implementation: throw an exceoption)
|
2010-08-03 09:14:57 +00:00
|
|
|
|
2012-04-23 13:27:03 +00:00
|
|
|
virtual boost::shared_ptr<Action> activate (const Ptr& ptr, const Ptr& actor) const;
|
2010-08-03 16:20:15 +00:00
|
|
|
///< Generate action for activation (default implementation: return a null action).
|
|
|
|
|
2012-04-23 13:27:03 +00:00
|
|
|
virtual boost::shared_ptr<Action> use (const Ptr& ptr)
|
2010-08-03 16:44:52 +00:00
|
|
|
const;
|
2010-08-03 16:20:15 +00:00
|
|
|
///< Generate action for using via inventory menu (default implementation: return a
|
|
|
|
/// null action).
|
|
|
|
|
2012-01-28 10:45:55 +00:00
|
|
|
virtual ContainerStore& getContainerStore (const Ptr& ptr) const;
|
2010-08-04 12:37:23 +00:00
|
|
|
///< Return container store or throw an exception, if class does not have a
|
|
|
|
/// container store (default implementation: throw an exceoption)
|
|
|
|
|
2012-03-10 11:49:54 +00: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 09:56:55 +00: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 13:40:03 +00: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 09:45:29 +00: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;
|
2012-05-12 14:17:03 +00:00
|
|
|
///< Check if a stance is active or not.
|
2011-01-18 09:45:29 +00:00
|
|
|
|
|
|
|
virtual float getSpeed (const Ptr& ptr) const;
|
|
|
|
///< Return movement speed.
|
|
|
|
|
2013-02-24 11:30:33 +00:00
|
|
|
virtual float getJump(const MWWorld::Ptr &ptr) const;
|
|
|
|
///< Return jump velocity (not accounting for movement)
|
|
|
|
|
2011-02-03 10:37:17 +00: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).
|
|
|
|
|
2013-03-31 08:29:24 +00:00
|
|
|
virtual Ogre::Vector3 getRotationVector (const Ptr& ptr) const;
|
|
|
|
///< Return desired rotations, as euler angles.
|
|
|
|
|
2012-03-13 13:12:07 +00:00
|
|
|
virtual std::pair<std::vector<int>, bool> getEquipmentSlots (const Ptr& ptr) const;
|
2012-03-13 12:45:50 +00: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-04-23 13:27:03 +00:00
|
|
|
virtual int getEquipmentSkill (const Ptr& ptr)
|
2012-03-13 13:12:07 +00: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)
|
|
|
|
|
2012-04-07 17:53:49 +00:00
|
|
|
virtual int getValue (const Ptr& ptr) const;
|
|
|
|
///< Return trade value of the object. Throws an exception, if the object can't be traded.
|
|
|
|
/// (default implementation: throws an exception)
|
|
|
|
|
2012-05-15 20:31:52 +00:00
|
|
|
virtual float getCapacity (const MWWorld::Ptr& ptr) const;
|
2012-05-15 19:34:00 +00:00
|
|
|
///< Return total weight that fits into the object. Throws an exception, if the object can't
|
|
|
|
/// hold other objects.
|
|
|
|
/// (default implementation: throws an exception)
|
|
|
|
|
|
|
|
virtual float getEncumbrance (const MWWorld::Ptr& ptr) const;
|
|
|
|
///< Returns total weight of objects inside this object (including modifications from magic
|
2012-05-15 19:17:00 +00:00
|
|
|
/// effects). Throws an exception, if the object can't hold other objects.
|
|
|
|
/// (default implementation: throws an exception)
|
|
|
|
|
2012-07-13 06:50:46 +00:00
|
|
|
virtual bool apply (const MWWorld::Ptr& ptr, const std::string& id,
|
|
|
|
const MWWorld::Ptr& actor) const;
|
2012-06-24 14:23:43 +00:00
|
|
|
///< Apply \a id on \a ptr.
|
2012-07-13 06:50:46 +00:00
|
|
|
/// \param actor Actor that is resposible for the ID being applied to \a ptr.
|
2012-06-24 14:23:43 +00:00
|
|
|
/// \return Any effect?
|
|
|
|
///
|
|
|
|
/// (default implementation: ignore and return false)
|
|
|
|
|
2012-07-13 07:03:17 +00:00
|
|
|
virtual void skillUsageSucceeded (const MWWorld::Ptr& ptr, int skill, int usageType) const;
|
|
|
|
///< Inform actor \a ptr that a skill use has succeeded.
|
|
|
|
///
|
|
|
|
/// (default implementations: throws an exception)
|
|
|
|
|
2012-10-27 11:33:54 +00:00
|
|
|
virtual bool isEssential (const MWWorld::Ptr& ptr) const;
|
|
|
|
///< Is \a ptr essential? (i.e. may losing \a ptr make the game unwinnable)
|
|
|
|
///
|
|
|
|
/// (default implementation: return false)
|
|
|
|
|
2012-11-15 19:00:27 +00:00
|
|
|
virtual bool hasDetected (const MWWorld::Ptr& ptr, const MWWorld::Ptr& ptr2) const;
|
|
|
|
///< Has \æ ptr detected \a ptr2?
|
|
|
|
///
|
|
|
|
/// (default implementation: return false)
|
|
|
|
|
2010-08-03 09:14:57 +00: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 09:49:12 +00:00
|
|
|
static const Class& get (const Ptr& ptr);
|
|
|
|
///< If there is no class for this pointer, an exception is thrown.
|
|
|
|
|
2010-08-03 09:14:57 +00:00
|
|
|
static void registerClass (const std::string& key, boost::shared_ptr<Class> instance);
|
2012-03-13 16:05:38 +00:00
|
|
|
|
2012-04-23 13:27:03 +00:00
|
|
|
virtual std::string getUpSoundId (const Ptr& ptr) const;
|
2012-03-13 16:05:38 +00: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-04-23 13:27:03 +00:00
|
|
|
virtual std::string getDownSoundId (const Ptr& ptr) const;
|
2012-03-13 16:05:38 +00: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)
|
2012-04-15 18:56:45 +00:00
|
|
|
|
2013-07-18 06:58:21 +00:00
|
|
|
virtual std::string getSoundIdFromSndGen(const Ptr &ptr, const std::string &type) const;
|
|
|
|
///< Returns the sound ID for \a ptr of the given soundgen \a type.
|
|
|
|
|
2013-03-17 21:29:12 +00:00
|
|
|
virtual float getArmorRating (const MWWorld::Ptr& ptr) const;
|
|
|
|
///< @return combined armor rating of this actor
|
|
|
|
|
2012-04-15 18:56:45 +00:00
|
|
|
virtual std::string getInventoryIcon (const MWWorld::Ptr& ptr) const;
|
|
|
|
///< Return name of inventory icon.
|
2012-05-12 16:32:06 +00:00
|
|
|
|
2012-05-12 14:17:03 +00:00
|
|
|
virtual std::string getEnchantment (const MWWorld::Ptr& ptr) const;
|
|
|
|
///< @return the enchantment ID if the object is enchanted, otherwise an empty string
|
|
|
|
/// (default implementation: return empty string)
|
2012-05-21 08:58:04 +00:00
|
|
|
|
2013-04-29 08:19:09 +00:00
|
|
|
virtual float getEnchantmentPoints (const MWWorld::Ptr& ptr) const;
|
2013-03-16 18:00:14 +00:00
|
|
|
///< @return the number of enchantment points available for possible enchanting
|
|
|
|
|
2012-05-25 16:23:06 +00:00
|
|
|
virtual void adjustScale(const MWWorld::Ptr& ptr,float& scale) const;
|
|
|
|
|
|
|
|
virtual void adjustRotation(const MWWorld::Ptr& ptr,float& x,float& y,float& z) const;
|
2012-07-24 14:52:08 +00:00
|
|
|
|
2013-04-07 19:38:53 +00:00
|
|
|
virtual bool canSell (const MWWorld::Ptr& item, int npcServices) const;
|
|
|
|
///< Determine whether or not \a item can be sold to an npc with the given \a npcServices
|
|
|
|
|
2013-05-11 16:38:27 +00:00
|
|
|
virtual int getServices (const MWWorld::Ptr& actor) const;
|
|
|
|
|
2012-07-24 16:22:11 +00:00
|
|
|
virtual std::string getModel(const MWWorld::Ptr &ptr) const;
|
2012-07-25 13:18:17 +00:00
|
|
|
|
2013-03-31 21:18:23 +00:00
|
|
|
virtual void applyEnchantment(const MWWorld::Ptr &ptr, const std::string& enchId, int enchCharge, const std::string& newName) const;
|
2013-03-28 16:41:00 +00:00
|
|
|
|
2013-04-15 00:56:23 +00:00
|
|
|
virtual std::pair<int, std::string> canBeEquipped(const MWWorld::Ptr &ptr, const MWWorld::Ptr &npc) const;
|
2013-04-08 20:10:55 +00:00
|
|
|
///< Return 0 if player cannot equip item. 1 if can equip. 2 if it's twohanded weapon. 3 if twohanded weapon conflicts with that.
|
2013-04-15 00:56:23 +00:00
|
|
|
/// Second item in the pair specifies the error message
|
2013-04-05 13:42:05 +00:00
|
|
|
|
2013-05-11 16:38:27 +00:00
|
|
|
virtual float getWeight (const MWWorld::Ptr& ptr) const;
|
|
|
|
|
2013-05-16 16:50:26 +00:00
|
|
|
virtual bool isPersistent (const MWWorld::Ptr& ptr) const;
|
|
|
|
|
2012-07-25 13:18:17 +00:00
|
|
|
virtual Ptr
|
2012-07-26 12:14:11 +00:00
|
|
|
copyToCell(const Ptr &ptr, CellStore &cell) const;
|
2012-07-25 13:18:17 +00:00
|
|
|
|
|
|
|
virtual Ptr
|
2012-07-26 12:14:11 +00:00
|
|
|
copyToCell(const Ptr &ptr, CellStore &cell, const ESM::Position &pos) const;
|
2012-07-30 19:28:14 +00:00
|
|
|
|
|
|
|
virtual bool
|
|
|
|
isActor() const {
|
|
|
|
return false;
|
|
|
|
}
|
2010-08-03 09:14:57 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|