Path: blob/master/thirdparty/jolt_physics/Jolt/Skeleton/SkeletonPose.cpp
9912 views
// Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)1// SPDX-FileCopyrightText: 2021 Jorrit Rouwe2// SPDX-License-Identifier: MIT34#include <Jolt/Jolt.h>56#include <Jolt/Skeleton/SkeletonPose.h>7#ifdef JPH_DEBUG_RENDERER8#include <Jolt/Renderer/DebugRenderer.h>9#endif // JPH_DEBUG_RENDERER1011JPH_NAMESPACE_BEGIN1213void SkeletonPose::SetSkeleton(const Skeleton *inSkeleton)14{15mSkeleton = inSkeleton;1617mJoints.resize(mSkeleton->GetJointCount());18mJointMatrices.resize(mSkeleton->GetJointCount());19}2021void SkeletonPose::CalculateJointMatrices()22{23for (int i = 0; i < (int)mJoints.size(); ++i)24{25mJointMatrices[i] = mJoints[i].ToMatrix();2627int parent = mSkeleton->GetJoint(i).mParentJointIndex;28if (parent >= 0)29{30JPH_ASSERT(parent < i, "Joints must be ordered: parents first");31mJointMatrices[i] = mJointMatrices[parent] * mJointMatrices[i];32}33}34}3536void SkeletonPose::CalculateJointStates()37{38for (int i = 0; i < (int)mJoints.size(); ++i)39{40Mat44 local_transform;41int parent = mSkeleton->GetJoint(i).mParentJointIndex;42if (parent >= 0)43local_transform = mJointMatrices[parent].Inversed() * mJointMatrices[i];44else45local_transform = mJointMatrices[i];4647JointState &joint = mJoints[i];48joint.mTranslation = local_transform.GetTranslation();49joint.mRotation = local_transform.GetQuaternion();50}51}5253void SkeletonPose::CalculateLocalSpaceJointMatrices(Mat44 *outMatrices) const54{55for (int i = 0; i < (int)mJoints.size(); ++i)56outMatrices[i] = mJoints[i].ToMatrix();57}5859#ifdef JPH_DEBUG_RENDERER60void SkeletonPose::Draw(const DrawSettings &inDrawSettings, DebugRenderer *inRenderer, RMat44Arg inOffset) const61{62RMat44 offset = inOffset * RMat44::sTranslation(mRootOffset);6364const Skeleton::JointVector &joints = mSkeleton->GetJoints();6566for (int b = 0; b < mSkeleton->GetJointCount(); ++b)67{68RMat44 joint_transform = offset * mJointMatrices[b];6970if (inDrawSettings.mDrawJoints)71{72int parent = joints[b].mParentJointIndex;73if (parent >= 0)74inRenderer->DrawLine(offset * mJointMatrices[parent].GetTranslation(), joint_transform.GetTranslation(), Color::sGreen);75}7677if (inDrawSettings.mDrawJointOrientations)78inRenderer->DrawCoordinateSystem(joint_transform, 0.05f);7980if (inDrawSettings.mDrawJointNames)81inRenderer->DrawText3D(joint_transform.GetTranslation(), joints[b].mName, Color::sWhite, 0.05f);82}83}84#endif // JPH_DEBUG_RENDERER8586JPH_NAMESPACE_END878889