VehicleSixDOFTest.h 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. // Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
  2. // SPDX-FileCopyrightText: 2021 Jorrit Rouwe
  3. // SPDX-License-Identifier: MIT
  4. #pragma once
  5. #include <Tests/Vehicle/VehicleTest.h>
  6. #include <Jolt/Physics/Constraints/SixDOFConstraint.h>
  7. // This test shows how a vehicle could be made with the SixDOF constraint.
  8. class VehicleSixDOFTest : public VehicleTest
  9. {
  10. public:
  11. JPH_DECLARE_RTTI_VIRTUAL(JPH_NO_EXPORT, VehicleSixDOFTest)
  12. // See: Test
  13. virtual void Initialize() override;
  14. virtual void PrePhysicsUpdate(const PreUpdateParams &inParams) override;
  15. virtual void GetInitialCamera(CameraState &ioState) const override;
  16. virtual RMat44 GetCameraPivot(float inCameraHeading, float inCameraPitch) const override;
  17. private:
  18. static constexpr float cMaxSteeringAngle = DegreesToRadians(30);
  19. using EAxis = SixDOFConstraintSettings::EAxis;
  20. enum class EWheel : int
  21. {
  22. LeftFront,
  23. RightFront,
  24. LeftRear,
  25. RightRear,
  26. Num,
  27. };
  28. static inline bool sIsFrontWheel(EWheel inWheel) { return inWheel == EWheel::LeftFront || inWheel == EWheel::RightFront; }
  29. static inline bool sIsLeftWheel(EWheel inWheel) { return inWheel == EWheel::LeftFront || inWheel == EWheel::LeftRear; }
  30. Body * mCarBody;
  31. Ref<SixDOFConstraint> mWheels[int(EWheel::Num)];
  32. };