1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-24 11:23:52 +00:00
openmw/components/sceneutil/positionattitudetransform.cpp

49 lines
1.4 KiB
C++
Raw Normal View History

#include "positionattitudetransform.hpp"
namespace SceneUtil
{
2022-09-22 18:26:05 +00:00
PositionAttitudeTransform::PositionAttitudeTransform()
: _scale(1.0, 1.0, 1.0)
{
}
2022-09-22 18:26:05 +00:00
bool PositionAttitudeTransform::computeLocalToWorldMatrix(osg::Matrix& matrix, osg::NodeVisitor*) const
{
2022-09-22 18:26:05 +00:00
if (_referenceFrame == RELATIVE_RF)
{
matrix.preMultTranslate(_position);
matrix.preMultRotate(_attitude);
matrix.preMultScale(_scale);
}
else // absolute
{
matrix.makeRotate(_attitude);
matrix.postMultTranslate(_position);
matrix.preMultScale(_scale);
}
return true;
}
2022-09-22 18:26:05 +00:00
bool PositionAttitudeTransform::computeWorldToLocalMatrix(osg::Matrix& matrix, osg::NodeVisitor*) const
{
2022-09-22 18:26:05 +00:00
if (_scale.x() == 0.0 || _scale.y() == 0.0 || _scale.z() == 0.0)
return false;
if (_referenceFrame == RELATIVE_RF)
{
matrix.postMultTranslate(-_position);
matrix.postMultRotate(_attitude.inverse());
matrix.postMultScale(osg::Vec3f(1.0 / _scale.x(), 1.0 / _scale.y(), 1.0 / _scale.z()));
}
else // absolute
{
matrix.makeRotate(_attitude.inverse());
matrix.preMultTranslate(-_position);
matrix.postMultScale(osg::Vec3f(1.0 / _scale.x(), 1.0 / _scale.y(), 1.0 / _scale.z()));
}
return true;
}
}