1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00
OpenMW/apps/openmw/mwworld/inventorystore.hpp

145 lines
5.7 KiB
C++
Raw Normal View History

#ifndef GAME_MWWORLD_INVENTORYSTORE_H
#define GAME_MWWORLD_INVENTORYSTORE_H
#include "containerstore.hpp"
#include "../mwmechanics/magiceffects.hpp"
namespace MWMechanics
{
class NpcStats;
}
namespace MWWorld
{
///< \brief Variant of the ContainerStore for NPCs
class InventoryStore : public ContainerStore
{
2012-03-13 13:31:11 +01:00
public:
2012-03-13 13:31:11 +01:00
static const int Slot_Helmet = 0;
static const int Slot_Cuirass = 1;
static const int Slot_Greaves = 2;
static const int Slot_LeftPauldron = 3;
static const int Slot_RightPauldron = 4;
static const int Slot_LeftGauntlet = 5;
static const int Slot_RightGauntlet = 6;
static const int Slot_Boots = 7;
static const int Slot_Shirt = 8;
static const int Slot_Pants = 9;
static const int Slot_Skirt = 10;
static const int Slot_Robe = 11;
static const int Slot_LeftRing = 12;
static const int Slot_RightRing = 13;
static const int Slot_Amulet = 14;
static const int Slot_Belt = 15;
static const int Slot_CarriedRight = 16;
static const int Slot_CarriedLeft = 17;
static const int Slot_Ammunition = 18;
2012-03-13 13:31:11 +01:00
static const int Slots = 19;
static const int Slot_NoSlot = -1;
private:
MWMechanics::MagicEffects mMagicEffects;
// Enables updates of magic effects and actor model whenever items are equipped or unequipped.
// This is disabled during autoequip to avoid excessive updates
bool mUpdatesEnabled;
bool mFirstAutoEquip;
// Vanilla allows permanent effects with a random magnitude, so it needs to be stored here.
// We also need this to only play sounds and particle effects when the item is equipped, rather than on every update.
typedef std::map<std::string, std::vector<float> > TEffectMagnitudes;
TEffectMagnitudes mPermanentMagicEffectMagnitudes;
typedef std::vector<ContainerStoreIterator> TSlots;
TSlots mSlots;
2012-03-13 13:31:11 +01:00
2012-05-29 12:35:03 +02:00
// selected magic item (for using enchantments of type "Cast once" or "Cast when used")
ContainerStoreIterator mSelectedEnchantItem;
2012-03-13 13:31:11 +01:00
void copySlots (const InventoryStore& store);
void initSlots (TSlots& slots_);
2013-10-25 22:16:52 +02:00
void updateActorModel (const Ptr& actor);
void updateMagicEffects(const Ptr& actor);
2012-03-13 13:31:11 +01:00
public:
InventoryStore();
InventoryStore (const InventoryStore& store);
InventoryStore& operator= (const InventoryStore& store);
virtual ContainerStoreIterator add (const Ptr& itemPtr, const Ptr& actorPtr);
///< Add the item pointed to by \a ptr to this container. (Stacks automatically if needed)
/// Auto-equip items if specific conditions are fulfilled (see the implementation).
///
/// \note The item pointed to is not required to exist beyond this function call.
///
/// \attention Do not add items to an existing stack by increasing the count instead of
/// calling this function!
///
/// @return if stacking happened, return iterator to the item that was stacked against, otherwise iterator to the newly inserted item.
void equip (int slot, const ContainerStoreIterator& iterator, const Ptr& actor);
2012-05-29 12:35:03 +02:00
///< \note \a iterator can be an end-iterator
void setSelectedEnchantItem(const ContainerStoreIterator& iterator);
///< set the selected magic item (for using enchantments of type "Cast once" or "Cast when used")
/// \note to unset the selected item, call this method with end() iterator
ContainerStoreIterator getSelectedEnchantItem();
///< @return selected magic item (for using enchantments of type "Cast once" or "Cast when used")
/// \note if no item selected, return end() iterator
2012-03-13 13:31:11 +01:00
ContainerStoreIterator getSlot (int slot);
2013-08-06 14:55:08 +02:00
void unequipAll(const MWWorld::Ptr& actor);
///< Unequip all currently equipped items.
2013-04-05 15:42:05 +02:00
void autoEquip (const MWWorld::Ptr& npc);
///< Auto equip items according to stats and item value.
2012-05-13 14:58:38 +02:00
const MWMechanics::MagicEffects& getMagicEffects() const;
///< Return magic effects from worn items.
virtual void flagAsModified();
///< \attention This function is internal to the world model and should not be called from
/// outside.
2013-11-12 23:12:56 +01:00
virtual bool stacks (const Ptr& ptr1, const Ptr& ptr2);
2012-05-13 14:58:38 +02:00
///< @return true if the two specified objects can stack with each other
virtual int remove(const Ptr& item, int count, const Ptr& actor);
///< Remove \a count item(s) designated by \a item from this inventory.
///
/// @return the number of items actually removed
ContainerStoreIterator unequipSlot(int slot, const Ptr& actor, bool restack = true);
///< Unequip \a slot.
///
/// @return an iterator to the item that was previously in the slot
/// (if \a restack is true, the item can be re-stacked so its count
/// may differ from when it was equipped).
2013-11-01 00:21:15 +01:00
ContainerStoreIterator unequipItem(const Ptr& item, const Ptr& actor);
///< Unequip an item identified by its Ptr. An exception is thrown
/// if the item is not currently equipped.
///
/// @return an iterator to the item that was previously in the slot
/// (it can be re-stacked so its count may be different than when it
/// was equipped).
};
}
#endif