1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-30 12:32:36 +00:00
OpenMW/apps/openmw/mwrender/rotatecontroller.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

70 lines
1.7 KiB
C++
Raw Normal View History

2015-05-31 18:53:16 +02:00
#include "rotatecontroller.hpp"
#include <osg/MatrixTransform>
#include <osgAnimation/Bone>
2015-05-31 18:53:16 +02:00
namespace MWRender
{
RotateController::RotateController(osg::Node* relativeTo)
: mEnabled(true)
, mRelativeTo(relativeTo)
{
}
void RotateController::setEnabled(bool enabled)
{
mEnabled = enabled;
}
void RotateController::setRotate(const osg::Quat& rotate)
{
mRotate = rotate;
}
void RotateController::setOffset(const osg::Vec3f& offset)
2015-05-31 18:53:16 +02:00
{
mOffset = offset;
}
void RotateController::operator()(osg::MatrixTransform* node, osg::NodeVisitor* nv)
2022-09-22 21:26:05 +03:00
{
2015-05-31 18:53:16 +02:00
if (!mEnabled)
2022-09-22 21:26:05 +03:00
{
2015-05-31 18:53:16 +02:00
traverse(node, nv);
2022-09-22 21:26:05 +03:00
return;
}
osg::Matrix matrix = node->getMatrix();
osg::Quat worldOrient;
osg::NodePathList nodepaths = node->getParentalNodePaths(mRelativeTo);
if (!nodepaths.empty())
{
osg::Matrixf worldMat = osg::computeLocalToWorld(nodepaths[0]);
worldOrient = worldMat.getRotate();
}
osg::Quat worldOrientInverse = worldOrient.inverse();
2022-09-22 21:26:05 +03:00
osg::Quat orient = worldOrient * mRotate * worldOrientInverse * matrix.getRotate();
2015-05-31 18:53:16 +02:00
matrix.setRotate(orient);
matrix.setTrans(matrix.getTrans() + worldOrientInverse * mOffset);
node->setMatrix(matrix);
2015-05-31 18:53:16 +02:00
// If we are linked to a bone we must call setMatrixInSkeletonSpace
osgAnimation::Bone* b = dynamic_cast<osgAnimation::Bone*>(node);
if (b)
{
osgAnimation::Bone* parent = b->getBoneParent();
if (parent)
matrix *= parent->getMatrixInSkeletonSpace();
b->setMatrixInSkeletonSpace(matrix);
}
2015-05-31 18:53:16 +02:00
traverse(node, nv);
}
}