forked from Mirrorlandia_minetest/irrlicht
Avoid some broken calculations for IBoneSceneNode positions.
This is based on bugreport #458 reported by viwrap who also made a nice test-case model. Note: While solution seems to work and would even be faster, I'm not 100% sure yet if there are no downsides. The other solution seems to regard last column in matrices - thought I don't think we ever set or use that. And I also haven't found out yet _why_ the original solution goes wrong. But animation system uses right-hand quaternions unlike rest of Irrlicht which is obviously a bit dangerous, will have to check the conversions some day. git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/trunk@6438 dfc29bdd-3216-0410-991c-e03cc46cb475
This commit is contained in:
parent
8ffa7eafea
commit
edb381bd50
@ -1347,9 +1347,24 @@ void CSkinnedMesh::recoverJointsFromMesh(core::array<IBoneSceneNode*> &jointChil
|
||||
{
|
||||
IBoneSceneNode* node=jointChildSceneNodes[i];
|
||||
SJoint *joint=AllJoints[i];
|
||||
|
||||
if ( joint->UseAnimationFrom ) // Seems to work better (else solution seems to mess up sometimes) and would be faster. Any disadvantage?
|
||||
{
|
||||
node->setPosition(joint->Animatedposition);
|
||||
core::quaternion qrot = joint->Animatedrotation;
|
||||
qrot.W *= -1.f; // Animation system uses right-handed rotations? Argh...
|
||||
irr::core::vector3df euler;
|
||||
qrot.toEuler(euler);
|
||||
euler *= core::RADTODEG;
|
||||
node->setRotation(euler);
|
||||
node->setScale(joint->Animatedscale);
|
||||
}
|
||||
else
|
||||
{
|
||||
node->setPosition(joint->LocalAnimatedMatrix.getTranslation());
|
||||
node->setRotation(joint->LocalAnimatedMatrix.getRotationDegrees());
|
||||
node->setScale(joint->LocalAnimatedMatrix.getScale());
|
||||
}
|
||||
|
||||
node->positionHint=joint->positionHint;
|
||||
node->scaleHint=joint->scaleHint;
|
||||
|
Loading…
Reference in New Issue
Block a user