2020-06-30 20:27:46 +00:00
|
|
|
#include "matrixtransform.hpp"
|
|
|
|
|
|
|
|
namespace NifOsg
|
|
|
|
{
|
2020-07-12 12:34:22 +00:00
|
|
|
MatrixTransform::MatrixTransform(const Nif::Transformation &trafo)
|
2020-06-30 20:27:46 +00:00
|
|
|
: osg::MatrixTransform(trafo.toMatrix())
|
|
|
|
, mScale(trafo.scale)
|
|
|
|
, mRotationScale(trafo.rotation)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
MatrixTransform::MatrixTransform(const MatrixTransform ©, const osg::CopyOp ©op)
|
|
|
|
: osg::MatrixTransform(copy, copyop)
|
|
|
|
, mScale(copy.mScale)
|
|
|
|
, mRotationScale(copy.mRotationScale)
|
|
|
|
{
|
|
|
|
}
|
2022-06-07 21:16:16 +00:00
|
|
|
|
|
|
|
void MatrixTransform::setScale(float scale)
|
|
|
|
{
|
2022-06-11 02:44:35 +00:00
|
|
|
// Update the decomposed scale.
|
|
|
|
mScale = scale;
|
2022-06-07 21:16:16 +00:00
|
|
|
|
2022-06-11 02:44:35 +00:00
|
|
|
// Rescale the node using the known components.
|
2022-06-07 21:16:16 +00:00
|
|
|
for (int i = 0; i < 3; ++i)
|
|
|
|
for (int j = 0; j < 3; ++j)
|
2022-06-11 02:44:35 +00:00
|
|
|
_matrix(i,j) = mRotationScale.mValues[j][i] * mScale; // NB: column/row major difference
|
2022-06-07 21:16:16 +00:00
|
|
|
|
|
|
|
_inverseDirty = true;
|
|
|
|
dirtyBound();
|
|
|
|
}
|
|
|
|
|
|
|
|
void MatrixTransform::setRotation(const osg::Quat &rotation)
|
|
|
|
{
|
|
|
|
// First override the rotation ignoring the scale.
|
|
|
|
_matrix.setRotate(rotation);
|
2022-06-11 02:44:35 +00:00
|
|
|
|
2022-06-07 21:16:16 +00:00
|
|
|
for (int i = 0; i < 3; ++i)
|
|
|
|
{
|
|
|
|
for (int j = 0; j < 3; ++j)
|
|
|
|
{
|
|
|
|
// Update the current decomposed rotation and restore the known scale.
|
|
|
|
mRotationScale.mValues[j][i] = _matrix(i,j); // NB: column/row major difference
|
|
|
|
_matrix(i,j) *= mScale;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_inverseDirty = true;
|
|
|
|
dirtyBound();
|
|
|
|
}
|
|
|
|
|
2022-06-11 02:44:35 +00:00
|
|
|
void MatrixTransform::setRotation(const Nif::Matrix3 &rotation)
|
|
|
|
{
|
|
|
|
// Update the decomposed rotation.
|
|
|
|
mRotationScale = rotation;
|
|
|
|
|
|
|
|
// Reorient the node using the known components.
|
|
|
|
for (int i = 0; i < 3; ++i)
|
|
|
|
for (int j = 0; j < 3; ++j)
|
|
|
|
_matrix(i,j) = mRotationScale.mValues[j][i] * mScale; // NB: column/row major difference
|
|
|
|
|
|
|
|
_inverseDirty = true;
|
|
|
|
dirtyBound();
|
|
|
|
}
|
|
|
|
|
2022-06-07 21:16:16 +00:00
|
|
|
void MatrixTransform::setTranslation(const osg::Vec3f &translation)
|
|
|
|
{
|
|
|
|
// The translation is independent from the rotation and scale so we can apply it directly.
|
|
|
|
_matrix.setTrans(translation);
|
|
|
|
|
|
|
|
_inverseDirty = true;
|
|
|
|
dirtyBound();
|
|
|
|
}
|
2020-06-30 20:27:46 +00:00
|
|
|
}
|