|
|
@ -1815,33 +1815,30 @@ namespace MWRender
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mHeadController = nullptr;
|
|
|
|
mHeadController = nullptr;
|
|
|
|
|
|
|
|
|
|
|
|
if (mPtr.getClass().isBipedal(mPtr))
|
|
|
|
NodeMap::const_iterator found = getNodeMap().find("bip01 head");
|
|
|
|
{
|
|
|
|
if (found == getNodeMap().end())
|
|
|
|
NodeMap::const_iterator found = getNodeMap().find("bip01 head");
|
|
|
|
return;
|
|
|
|
if (found != getNodeMap().end())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
osg::MatrixTransform* node = found->second;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool foundKeyframeCtrl = false;
|
|
|
|
osg::MatrixTransform* node = found->second;
|
|
|
|
osg::Callback* cb = node->getUpdateCallback();
|
|
|
|
|
|
|
|
while (cb)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (dynamic_cast<NifOsg::KeyframeController*>(cb))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
foundKeyframeCtrl = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
cb = cb->getNestedCallback();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (foundKeyframeCtrl)
|
|
|
|
bool foundKeyframeCtrl = false;
|
|
|
|
{
|
|
|
|
osg::Callback* cb = node->getUpdateCallback();
|
|
|
|
mHeadController = new RotateController(mObjectRoot.get());
|
|
|
|
while (cb)
|
|
|
|
node->addUpdateCallback(mHeadController);
|
|
|
|
{
|
|
|
|
mActiveControllers.emplace_back(node, mHeadController);
|
|
|
|
if (dynamic_cast<NifOsg::KeyframeController*>(cb))
|
|
|
|
}
|
|
|
|
{
|
|
|
|
|
|
|
|
foundKeyframeCtrl = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
cb = cb->getNestedCallback();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!foundKeyframeCtrl)
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mHeadController = new RotateController(mObjectRoot.get());
|
|
|
|
|
|
|
|
node->addUpdateCallback(mHeadController);
|
|
|
|
|
|
|
|
mActiveControllers.emplace_back(node, mHeadController);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Animation::setHeadPitch(float pitchRadians)
|
|
|
|
void Animation::setHeadPitch(float pitchRadians)
|
|
|
|