Add part info for weapons and shields

This commit is contained in:
Chris Robinson 2013-01-06 05:39:39 -08:00
parent 976b042cca
commit 2b1fe7dc44
2 changed files with 20 additions and 24 deletions

View file

@ -17,7 +17,7 @@ using namespace NifOgre;
namespace MWRender
{
const PartInfo NpcAnimation::sPartList[NpcAnimation::sPartListSize] = {
const NpcAnimation::PartInfo NpcAnimation::sPartList[NpcAnimation::sPartListSize] = {
{ ESM::PRT_Head, &NpcAnimation::mHead, "Head" },
{ ESM::PRT_Hair, &NpcAnimation::mHair, "Head" },
{ ESM::PRT_Neck, &NpcAnimation::mNeck, "Neck" },
@ -28,7 +28,7 @@ const PartInfo NpcAnimation::sPartList[NpcAnimation::sPartListSize] = {
{ ESM::PRT_LHand, &NpcAnimation::mHandL, "Left Hand" },
{ ESM::PRT_RWrist, &NpcAnimation::mWristR, "Right Wrist" },
{ ESM::PRT_LWrist, &NpcAnimation::mWristL, "Left Wrist" },
{ ESM::PRT_Shield, NULL, "" },
{ ESM::PRT_Shield, &NpcAnimation::mShield, "Shield" },
{ ESM::PRT_RForearm, &NpcAnimation::mForearmR, "Right Forearm" },
{ ESM::PRT_LForearm, &NpcAnimation::mForearmL, "Left Forearm" },
{ ESM::PRT_RUpperarm, &NpcAnimation::mUpperArmR, "Right Upper Arm" },
@ -43,24 +43,21 @@ const PartInfo NpcAnimation::sPartList[NpcAnimation::sPartListSize] = {
{ ESM::PRT_LLeg, &NpcAnimation::mUpperLegL, "Left Upper Leg" },
{ ESM::PRT_RPauldron, &NpcAnimation::mClavicleR, "Right Clavicle" },
{ ESM::PRT_LPauldron, &NpcAnimation::mClavicleL, "Left Clavicle" },
{ ESM::PRT_Weapon, NULL, "" },
{ ESM::PRT_Weapon, &NpcAnimation::mWeapon, "Weapon" },
{ ESM::PRT_Tail, &NpcAnimation::mTail, "Tail" }
};
NpcAnimation::~NpcAnimation()
{
for(size_t i = 0;i < sPartListSize;i++)
{
if(sPartList[i].ents)
removeEntities(this->*sPartList[i].ents);
}
removeEntities(this->*sPartList[i].ents);
}
NpcAnimation::NpcAnimation(const MWWorld::Ptr& ptr, Ogre::SceneNode* node, MWWorld::InventoryStore& inv, int visibilityFlags)
: Animation(),
mStateID(-1),
mInv(inv),
mStateID(-1),
mTimeToChange(0),
mVisibilityFlags(visibilityFlags),
mRobe(mInv.end()),
@ -78,10 +75,10 @@ NpcAnimation::NpcAnimation(const MWWorld::Ptr& ptr, Ogre::SceneNode* node, MWWor
{
mNpc = ptr.get<ESM::NPC>()->mBase;
for (int init = 0; init < 27; init++)
for(size_t i = 0;i < sPartListSize;i++)
{
mPartslots[init] = -1; //each slot is empty
mPartPriorities[init] = 0;
mPartslots[i] = -1; //each slot is empty
mPartPriorities[i] = 0;
}
const MWWorld::ESMStore &store =
@ -397,8 +394,7 @@ void NpcAnimation::removeIndividualPart(int type)
{
if(type == sPartList[i].type)
{
if(sPartList[i].ents)
removeEntities(this->*sPartList[i].ents);
removeEntities(this->*sPartList[i].ents);
break;
}
}
@ -436,8 +432,7 @@ bool NpcAnimation::addOrReplaceIndividualPart(int type, int group, int priority,
{
if(type == sPartList[i].type)
{
if(sPartList[i].ents)
this->*sPartList[i].ents = insertBoundedPart(mesh, group, sPartList[i].name);
this->*sPartList[i].ents = insertBoundedPart(mesh, group, sPartList[i].name);
break;
}
}

View file

@ -14,23 +14,22 @@ namespace ESM
namespace MWRender
{
class NpcAnimation;
class NpcAnimation : public Animation
{
public:
struct PartInfo {
ESM::PartReferenceType type;
NifOgre::EntityList NpcAnimation::*ents;
const char name[32];
};
class NpcAnimation : public Animation
{
private:
static const size_t sPartListSize = 27;
static const PartInfo sPartList[sPartListSize];
MWWorld::InventoryStore& mInv;
int mStateID;
int mPartslots[27]; //Each part slot is taken by clothing, armor, or is empty
int mPartPriorities[27];
//Bounded Parts
NifOgre::EntityList mClavicleL;
NifOgre::EntityList mClavicleR;
@ -54,6 +53,8 @@ private:
NifOgre::EntityList mHair;
NifOgre::EntityList mHandL;
NifOgre::EntityList mHandR;
NifOgre::EntityList mShield;
NifOgre::EntityList mWeapon;
NifOgre::EntityList mHead;
NifOgre::EntityList mChest;
NifOgre::EntityList mTail;
@ -79,8 +80,8 @@ private:
int mVisibilityFlags;
static const size_t sPartListSize = 27;
static const PartInfo sPartList[sPartListSize];
int mPartslots[sPartListSize]; //Each part slot is taken by clothing, armor, or is empty
int mPartPriorities[sPartListSize];
public:
NpcAnimation(const MWWorld::Ptr& ptr, Ogre::SceneNode* node,