Skeleton.cpp 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. // SPDX-FileCopyrightText: 2021 Jorrit Rouwe
  2. // SPDX-License-Identifier: MIT
  3. #include <Jolt.h>
  4. #include <Skeleton/Skeleton.h>
  5. #include <ObjectStream/TypeDeclarations.h>
  6. #include <Core/StreamIn.h>
  7. #include <Core/StreamOut.h>
  8. namespace JPH {
  9. JPH_IMPLEMENT_SERIALIZABLE_NON_VIRTUAL(Skeleton::Joint)
  10. {
  11. JPH_ADD_ATTRIBUTE(Joint, mName)
  12. JPH_ADD_ATTRIBUTE(Joint, mParentName)
  13. }
  14. JPH_IMPLEMENT_SERIALIZABLE_NON_VIRTUAL(Skeleton)
  15. {
  16. JPH_ADD_ATTRIBUTE(Skeleton, mJoints)
  17. }
  18. int Skeleton::GetJointIndex(const string &inName) const
  19. {
  20. for (int i = 0; i < (int)mJoints.size(); ++i)
  21. if (mJoints[i].mName == inName)
  22. return i;
  23. return -1;
  24. }
  25. void Skeleton::CalculateParentJointIndices()
  26. {
  27. for (Joint &j : mJoints)
  28. j.mParentJointIndex = GetJointIndex(j.mParentName);
  29. }
  30. void Skeleton::SaveBinaryState(StreamOut &inStream) const
  31. {
  32. inStream.Write((uint32)mJoints.size());
  33. for (const Joint &j : mJoints)
  34. {
  35. inStream.Write(j.mName);
  36. inStream.Write(j.mParentJointIndex);
  37. inStream.Write(j.mParentName);
  38. }
  39. }
  40. Skeleton::SkeletonResult Skeleton::sRestoreFromBinaryState(StreamIn &inStream)
  41. {
  42. Ref<Skeleton> skeleton = new Skeleton;
  43. uint32 len = 0;
  44. inStream.Read(len);
  45. skeleton->mJoints.resize(len);
  46. for (Joint &j : skeleton->mJoints)
  47. {
  48. inStream.Read(j.mName);
  49. inStream.Read(j.mParentJointIndex);
  50. inStream.Read(j.mParentName);
  51. }
  52. SkeletonResult result;
  53. if (inStream.IsEOF() || inStream.IsFailed())
  54. result.SetError("Failed to read skeleton from stream");
  55. else
  56. result.Set(skeleton);
  57. return result;
  58. }
  59. } // JPH