controller.cpp 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /*
  2. * Copyright (c) 2012-2015 Daniele Bartolini and individual contributors.
  3. * License: https://github.com/taylor001/crown/blob/master/LICENSE
  4. */
  5. #include "controller.h"
  6. #include "math_utils.h"
  7. #include "physics_resource.h"
  8. #include "scene_graph.h"
  9. #include "vector3.h"
  10. #include "physics_callback.h"
  11. #include "PxCapsuleController.h"
  12. #include "PxPhysicsAPI.h"
  13. using physx::PxCapsuleClimbingMode;
  14. using physx::PxCapsuleController;
  15. using physx::PxCapsuleControllerDesc;
  16. using physx::PxCCTNonWalkableMode;
  17. using physx::PxControllerFilters;
  18. using physx::PxControllerFlag;
  19. using physx::PxExtendedVec3;
  20. using physx::PxVec3;
  21. namespace crown
  22. {
  23. Controller::Controller(const ControllerResource* cr, SceneGraph& sg, UnitId id, PxPhysics* physics, PxControllerManager* manager)
  24. : m_resource(cr)
  25. , m_scene_graph(sg)
  26. , _unit_id(id)
  27. , m_manager(manager)
  28. , m_controller(NULL)
  29. {
  30. TransformInstance ti = sg.get(id);
  31. const Vector3 pos = sg.world_position(ti);
  32. PxCapsuleControllerDesc desc;
  33. desc.climbingMode = PxCapsuleClimbingMode::eCONSTRAINED;
  34. desc.nonWalkableMode = PxCCTNonWalkableMode::eFORCE_SLIDING;
  35. desc.radius = cr->radius;
  36. desc.height = cr->height;
  37. desc.slopeLimit = cos(cr->slope_limit);
  38. desc.stepOffset = cr->step_offset;
  39. desc.contactOffset = cr->contact_offset;
  40. desc.upDirection = PxVec3(0.0, 1.0, 0.0);
  41. desc.material = physics->createMaterial(0.5f, 0.5f, 0.5f);
  42. desc.position = PxExtendedVec3(pos.x, pos.y, pos.z);
  43. desc.reportCallback = &m_callback;
  44. CE_ASSERT(desc.isValid(), "Capsule is not valid");
  45. m_controller = manager->createController(desc);
  46. CE_ASSERT(m_controller, "Failed to create controller");
  47. }
  48. Controller::~Controller()
  49. {
  50. m_controller->release();
  51. }
  52. void Controller::move(const Vector3& pos)
  53. {
  54. const PxVec3 disp(pos.x, pos.y, pos.z);
  55. m_flags = m_controller->move(disp, 0.001, 1.0 / 60.0, PxControllerFilters());
  56. }
  57. void Controller::set_height(float height)
  58. {
  59. m_controller->resize(height);
  60. }
  61. Vector3 Controller::position() const
  62. {
  63. PxExtendedVec3 pos = m_controller->getPosition();
  64. return Vector3(pos.x, pos.y, pos.z);
  65. }
  66. bool Controller::collides_up() const
  67. {
  68. return (m_flags & PxControllerFlag::eCOLLISION_UP) != 0;
  69. }
  70. bool Controller::collides_down() const
  71. {
  72. return (m_flags & PxControllerFlag::eCOLLISION_DOWN) != 0;
  73. }
  74. bool Controller::collides_sides() const
  75. {
  76. return (m_flags & PxControllerFlag::eCOLLISION_SIDES) != 0;
  77. }
  78. void Controller::update()
  79. {
  80. TransformInstance ti = m_scene_graph.get(_unit_id);
  81. m_scene_graph.set_local_position(ti, position());
  82. }
  83. } // namespace crown