TwoBodyConstraint.cpp 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. // Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
  2. // SPDX-FileCopyrightText: 2021 Jorrit Rouwe
  3. // SPDX-License-Identifier: MIT
  4. #include <Jolt/Jolt.h>
  5. #include <Jolt/Physics/Constraints/TwoBodyConstraint.h>
  6. #include <Jolt/Physics/IslandBuilder.h>
  7. #include <Jolt/Physics/LargeIslandSplitter.h>
  8. #include <Jolt/Physics/Body/BodyManager.h>
  9. #ifdef JPH_DEBUG_RENDERER
  10. #include <Jolt/Renderer/DebugRenderer.h>
  11. #endif // JPH_DEBUG_RENDERER
  12. JPH_NAMESPACE_BEGIN
  13. JPH_IMPLEMENT_SERIALIZABLE_ABSTRACT(TwoBodyConstraintSettings)
  14. {
  15. JPH_ADD_BASE_CLASS(TwoBodyConstraintSettings, ConstraintSettings)
  16. }
  17. void TwoBodyConstraint::BuildIslands(uint32 inConstraintIndex, IslandBuilder &ioBuilder, BodyManager &inBodyManager)
  18. {
  19. // Activate bodies
  20. BodyID body_ids[2];
  21. int num_bodies = 0;
  22. if (mBody1->IsDynamic() && !mBody1->IsActive())
  23. body_ids[num_bodies++] = mBody1->GetID();
  24. if (mBody2->IsDynamic() && !mBody2->IsActive())
  25. body_ids[num_bodies++] = mBody2->GetID();
  26. if (num_bodies > 0)
  27. inBodyManager.ActivateBodies(body_ids, num_bodies);
  28. // Link the bodies into the same island
  29. ioBuilder.LinkConstraint(inConstraintIndex, mBody1->GetIndexInActiveBodiesInternal(), mBody2->GetIndexInActiveBodiesInternal());
  30. }
  31. uint TwoBodyConstraint::BuildIslandSplits(LargeIslandSplitter &ioSplitter) const
  32. {
  33. return ioSplitter.AssignSplit(mBody1, mBody2);
  34. }
  35. #ifdef JPH_DEBUG_RENDERER
  36. void TwoBodyConstraint::DrawConstraintReferenceFrame(DebugRenderer *inRenderer) const
  37. {
  38. RMat44 transform1 = mBody1->GetCenterOfMassTransform() * GetConstraintToBody1Matrix();
  39. RMat44 transform2 = mBody2->GetCenterOfMassTransform() * GetConstraintToBody2Matrix();
  40. inRenderer->DrawCoordinateSystem(transform1, 1.1f * mDrawConstraintSize);
  41. inRenderer->DrawCoordinateSystem(transform2, mDrawConstraintSize);
  42. }
  43. #endif // JPH_DEBUG_RENDERER
  44. JPH_NAMESPACE_END