|
|
@ -60,6 +60,21 @@ std::string getVampireHead(const std::string& race, bool female)
|
|
|
|
return "meshes\\" + sVampireMapping[thisCombination]->mModel;
|
|
|
|
return "meshes\\" + sVampireMapping[thisCombination]->mModel;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool isSkinned (NifOgre::ObjectScenePtr scene)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (scene->mSkelBase == NULL)
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
for(size_t j = 0; j < scene->mEntities.size(); j++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Ogre::Entity *ent = scene->mEntities[j];
|
|
|
|
|
|
|
|
if(scene->mSkelBase != ent && ent->hasSkeleton())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -611,10 +626,11 @@ Ogre::Vector3 NpcAnimation::runAnimation(float timepassed)
|
|
|
|
for(;ctrl != mObjectParts[i]->mControllers.end();++ctrl)
|
|
|
|
for(;ctrl != mObjectParts[i]->mControllers.end();++ctrl)
|
|
|
|
ctrl->update();
|
|
|
|
ctrl->update();
|
|
|
|
|
|
|
|
|
|
|
|
Ogre::Entity *ent = mObjectParts[i]->mSkelBase;
|
|
|
|
if (!isSkinned(mObjectParts[i]))
|
|
|
|
if(!ent) continue;
|
|
|
|
continue;
|
|
|
|
updateSkeletonInstance(baseinst, ent->getSkeleton());
|
|
|
|
|
|
|
|
ent->getAllAnimationStates()->_notifyDirty();
|
|
|
|
updateSkeletonInstance(baseinst, mObjectParts[i]->mSkelBase->getSkeleton());
|
|
|
|
|
|
|
|
mObjectParts[i]->mSkelBase->getAllAnimationStates()->_notifyDirty();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
return ret;
|
|
|
@ -697,6 +713,7 @@ bool NpcAnimation::addOrReplaceIndividualPart(ESM::PartReferenceType type, int g
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (isSkinned(mObjectParts[type]))
|
|
|
|
updateSkeletonInstance(mSkelBase->getSkeleton(), skel);
|
|
|
|
updateSkeletonInstance(mSkelBase->getSkeleton(), skel);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|