|
|
@ -263,17 +263,27 @@ void NpcAnimation::updateNpcBase()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (isVampire)
|
|
|
|
mHeadModel = "";
|
|
|
|
|
|
|
|
if (isVampire) // FIXME: fall back to regular head when getVampireHead fails?
|
|
|
|
mHeadModel = getVampireHead(mNpc->mRace, mNpc->mFlags & ESM::NPC::Female);
|
|
|
|
mHeadModel = getVampireHead(mNpc->mRace, mNpc->mFlags & ESM::NPC::Female);
|
|
|
|
else if (!mNpc->mHead.empty())
|
|
|
|
else if (!mNpc->mHead.empty())
|
|
|
|
mHeadModel = "meshes\\" + store.get<ESM::BodyPart>().find(mNpc->mHead)->mModel;
|
|
|
|
{
|
|
|
|
|
|
|
|
const ESM::BodyPart* bp = store.get<ESM::BodyPart>().search(mNpc->mHead);
|
|
|
|
|
|
|
|
if (bp)
|
|
|
|
|
|
|
|
mHeadModel = "meshes\\" + bp->mModel;
|
|
|
|
else
|
|
|
|
else
|
|
|
|
mHeadModel = "";
|
|
|
|
std::cerr << "Failed to load body part '" << mNpc->mHead << "'" << std::endl;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mHairModel = "";
|
|
|
|
if (!mNpc->mHair.empty())
|
|
|
|
if (!mNpc->mHair.empty())
|
|
|
|
mHairModel = "meshes\\" + store.get<ESM::BodyPart>().find(mNpc->mHair)->mModel;
|
|
|
|
{
|
|
|
|
|
|
|
|
const ESM::BodyPart* bp = store.get<ESM::BodyPart>().search(mNpc->mHair);
|
|
|
|
|
|
|
|
if (bp)
|
|
|
|
|
|
|
|
mHairModel = "meshes\\" + bp->mModel;
|
|
|
|
else
|
|
|
|
else
|
|
|
|
mHairModel = "";
|
|
|
|
std::cerr << "Failed to load body part '" << mNpc->mHair << "'" << std::endl;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool isBeast = (race->mData.mFlags & ESM::Race::Beast) != 0;
|
|
|
|
bool isBeast = (race->mData.mFlags & ESM::Race::Beast) != 0;
|
|
|
|