1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 06:35:30 +00:00

Avoiding holding the InventoryStore in the NpcAnimation class

This commit is contained in:
Chris Robinson 2013-02-23 08:03:52 -08:00
parent 0d0e75fe0b
commit a2eaec7878
3 changed files with 24 additions and 28 deletions

View File

@ -167,11 +167,7 @@ void Actors::updateObjectCell(const MWWorld::Ptr &ptr)
PtrAnimationMap::iterator iter = mAllActors.find(ptr);
if(iter != mAllActors.end())
{
/// \note Update key (Ptr's are compared only with refdata so mCell
/// on key is outdated), maybe redundant
NpcAnimation *anim = static_cast<NpcAnimation *>(iter->second);
anim->updateParts(MWWorld::Class::get(ptr).getInventoryStore(ptr));
Animation *anim = iter->second;
mAllActors.erase(iter);
mAllActors[ptr] = anim;
}

View File

@ -5,6 +5,8 @@
#include <OgreSubEntity.h>
#include "../mwworld/esmstore.hpp"
#include "../mwworld/inventorystore.hpp"
#include "../mwworld/class.hpp"
#include "../mwbase/environment.hpp"
#include "../mwbase/world.hpp"
@ -54,22 +56,21 @@ NpcAnimation::~NpcAnimation()
NpcAnimation::NpcAnimation(const MWWorld::Ptr& ptr, Ogre::SceneNode* node, MWWorld::InventoryStore& inv, int visibilityFlags)
: Animation(ptr),
mInv(&inv),
mStateID(-1),
mTimeToChange(0),
mVisibilityFlags(visibilityFlags),
mRobe(mInv->end()),
mHelmet(mInv->end()),
mShirt(mInv->end()),
mCuirass(mInv->end()),
mGreaves(mInv->end()),
mPauldronL(mInv->end()),
mPauldronR(mInv->end()),
mBoots(mInv->end()),
mPants(mInv->end()),
mGloveL(mInv->end()),
mGloveR(mInv->end()),
mSkirtIter(mInv->end())
mRobe(inv.end()),
mHelmet(inv.end()),
mShirt(inv.end()),
mCuirass(inv.end()),
mGreaves(inv.end()),
mPauldronL(inv.end()),
mPauldronR(inv.end()),
mBoots(inv.end()),
mPants(inv.end()),
mGloveL(inv.end()),
mGloveR(inv.end()),
mSkirtIter(inv.end())
{
mNpc = mPtr.get<ESM::NPC>()->mBase;
@ -213,9 +214,10 @@ void NpcAnimation::updateParts(bool forceupdate)
};
static const size_t slotlistsize = sizeof(slotlist)/sizeof(slotlist[0]);
MWWorld::InventoryStore &inv = MWWorld::Class::get(mPtr).getInventoryStore(mPtr);
for(size_t i = 0;!forceupdate && i < slotlistsize;i++)
{
MWWorld::ContainerStoreIterator iter = mInv->getSlot(slotlist[i].slot);
MWWorld::ContainerStoreIterator iter = inv.getSlot(slotlist[i].slot);
if(this->*slotlist[i].part != iter)
{
forceupdate = true;
@ -227,12 +229,12 @@ void NpcAnimation::updateParts(bool forceupdate)
for(size_t i = 0;i < slotlistsize;i++)
{
MWWorld::ContainerStoreIterator iter = mInv->getSlot(slotlist[i].slot);
MWWorld::ContainerStoreIterator iter = inv.getSlot(slotlist[i].slot);
this->*slotlist[i].part = iter;
removePartGroup(slotlist[i].slot);
if(this->*slotlist[i].part == mInv->end())
if(this->*slotlist[i].part == inv.end())
continue;
for(int rem = 0;rem < slotlist[i].numRemoveParts;rem++)

View File

@ -3,7 +3,6 @@
#include "animation.hpp"
#include "../mwworld/inventorystore.hpp"
#include "../mwworld/containerstore.hpp"
namespace ESM
@ -11,6 +10,11 @@ namespace ESM
struct NPC;
}
namespace MWWorld
{
class InventoryStore;
}
namespace MWRender
{
@ -26,7 +30,6 @@ private:
static const size_t sPartListSize = 27;
static const PartInfo sPartList[sPartListSize];
MWWorld::InventoryStore *mInv;
int mStateID;
// Bounded Parts
@ -75,11 +78,6 @@ public:
virtual Ogre::Vector3 runAnimation(float timepassed);
void updateParts(MWWorld::InventoryStore &inventory)
{
mInv = &inventory;
updateParts(true);
}
void forceUpdate()
{ updateParts(true); }
};