Layers.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. // SPDX-FileCopyrightText: 2021 Jorrit Rouwe
  2. // SPDX-License-Identifier: MIT
  3. #pragma once
  4. #include <Jolt/Physics/Collision/ObjectLayer.h>
  5. #include <Jolt/Physics/Collision/BroadPhase/BroadPhaseLayer.h>
  6. /// Layer that objects can be in, determines which other objects it can collide with
  7. namespace Layers
  8. {
  9. static constexpr uint8 UNUSED1 = 0; // 4 unused values so that broadphase layers values don't match with object layer values (for testing purposes)
  10. static constexpr uint8 UNUSED2 = 1;
  11. static constexpr uint8 UNUSED3 = 2;
  12. static constexpr uint8 UNUSED4 = 3;
  13. static constexpr uint8 NON_MOVING = 4;
  14. static constexpr uint8 MOVING = 5;
  15. static constexpr uint8 DEBRIS = 6; // Example: Debris collides only with NON_MOVING
  16. static constexpr uint8 SENSOR = 7; // Sensors only collide with MOVING objects
  17. static constexpr uint8 NUM_LAYERS = 8;
  18. };
  19. /// Class that determines if two object layers can collide
  20. class ObjectLayerPairFilterImpl : public ObjectLayerPairFilter
  21. {
  22. public:
  23. virtual bool ShouldCollide(ObjectLayer inObject1, ObjectLayer inObject2) const override
  24. {
  25. switch (inObject1)
  26. {
  27. case Layers::UNUSED1:
  28. case Layers::UNUSED2:
  29. case Layers::UNUSED3:
  30. case Layers::UNUSED4:
  31. return false;
  32. case Layers::NON_MOVING:
  33. return inObject2 == Layers::MOVING || inObject2 == Layers::DEBRIS;
  34. case Layers::MOVING:
  35. return inObject2 == Layers::NON_MOVING || inObject2 == Layers::MOVING || inObject2 == Layers::SENSOR;
  36. case Layers::DEBRIS:
  37. return inObject2 == Layers::NON_MOVING;
  38. case Layers::SENSOR:
  39. return inObject2 == Layers::MOVING;
  40. default:
  41. JPH_ASSERT(false);
  42. return false;
  43. }
  44. }
  45. };
  46. /// Broadphase layers
  47. namespace BroadPhaseLayers
  48. {
  49. static constexpr BroadPhaseLayer NON_MOVING(0);
  50. static constexpr BroadPhaseLayer MOVING(1);
  51. static constexpr BroadPhaseLayer DEBRIS(2);
  52. static constexpr BroadPhaseLayer SENSOR(3);
  53. static constexpr BroadPhaseLayer UNUSED(4);
  54. static constexpr uint NUM_LAYERS(5);
  55. };
  56. /// BroadPhaseLayerInterface implementation
  57. class BPLayerInterfaceImpl final : public BroadPhaseLayerInterface
  58. {
  59. public:
  60. BPLayerInterfaceImpl()
  61. {
  62. // Create a mapping table from object to broad phase layer
  63. mObjectToBroadPhase[Layers::UNUSED1] = BroadPhaseLayers::UNUSED;
  64. mObjectToBroadPhase[Layers::UNUSED2] = BroadPhaseLayers::UNUSED;
  65. mObjectToBroadPhase[Layers::UNUSED3] = BroadPhaseLayers::UNUSED;
  66. mObjectToBroadPhase[Layers::UNUSED4] = BroadPhaseLayers::UNUSED;
  67. mObjectToBroadPhase[Layers::NON_MOVING] = BroadPhaseLayers::NON_MOVING;
  68. mObjectToBroadPhase[Layers::MOVING] = BroadPhaseLayers::MOVING;
  69. mObjectToBroadPhase[Layers::DEBRIS] = BroadPhaseLayers::DEBRIS;
  70. mObjectToBroadPhase[Layers::SENSOR] = BroadPhaseLayers::SENSOR;
  71. }
  72. virtual uint GetNumBroadPhaseLayers() const override
  73. {
  74. return BroadPhaseLayers::NUM_LAYERS;
  75. }
  76. virtual BroadPhaseLayer GetBroadPhaseLayer(ObjectLayer inLayer) const override
  77. {
  78. JPH_ASSERT(inLayer < Layers::NUM_LAYERS);
  79. return mObjectToBroadPhase[inLayer];
  80. }
  81. #if defined(JPH_EXTERNAL_PROFILE) || defined(JPH_PROFILE_ENABLED)
  82. virtual const char * GetBroadPhaseLayerName(BroadPhaseLayer inLayer) const override
  83. {
  84. switch ((BroadPhaseLayer::Type)inLayer)
  85. {
  86. case (BroadPhaseLayer::Type)BroadPhaseLayers::NON_MOVING: return "NON_MOVING";
  87. case (BroadPhaseLayer::Type)BroadPhaseLayers::MOVING: return "MOVING";
  88. case (BroadPhaseLayer::Type)BroadPhaseLayers::DEBRIS: return "DEBRIS";
  89. case (BroadPhaseLayer::Type)BroadPhaseLayers::SENSOR: return "SENSOR";
  90. case (BroadPhaseLayer::Type)BroadPhaseLayers::UNUSED: return "UNUSED";
  91. default: JPH_ASSERT(false); return "INVALID";
  92. }
  93. }
  94. #endif // JPH_EXTERNAL_PROFILE || JPH_PROFILE_ENABLED
  95. private:
  96. BroadPhaseLayer mObjectToBroadPhase[Layers::NUM_LAYERS];
  97. };
  98. /// Class that determines if an object layer can collide with a broadphase layer
  99. class ObjectVsBroadPhaseLayerFilterImpl : public ObjectVsBroadPhaseLayerFilter
  100. {
  101. public:
  102. virtual bool ShouldCollide(ObjectLayer inLayer1, BroadPhaseLayer inLayer2) const override
  103. {
  104. switch (inLayer1)
  105. {
  106. case Layers::NON_MOVING:
  107. return inLayer2 == BroadPhaseLayers::MOVING;
  108. case Layers::MOVING:
  109. return inLayer2 == BroadPhaseLayers::NON_MOVING || inLayer2 == BroadPhaseLayers::MOVING || inLayer2 == BroadPhaseLayers::SENSOR;
  110. case Layers::DEBRIS:
  111. return inLayer2 == BroadPhaseLayers::NON_MOVING;
  112. case Layers::SENSOR:
  113. return inLayer2 == BroadPhaseLayers::MOVING;
  114. case Layers::UNUSED1:
  115. case Layers::UNUSED2:
  116. case Layers::UNUSED3:
  117. return false;
  118. default:
  119. JPH_ASSERT(false);
  120. return false;
  121. }
  122. }
  123. };