BsPhysXBoxCollider.cpp 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #include "BsPhysXBoxCollider.h"
  2. #include "BsPhysX.h"
  3. #include "PxPhysics.h"
  4. #include "BsFPhysXCollider.h"
  5. using namespace physx;
  6. namespace BansheeEngine
  7. {
  8. PhysXBoxCollider::PhysXBoxCollider(PxPhysics* physx, const Vector3& position, const Quaternion& rotation,
  9. const Vector3& extents)
  10. :mExtents(extents)
  11. {
  12. PxBoxGeometry geometry(extents.x, extents.y, extents.z);
  13. PxShape* shape = physx->createShape(geometry, *gPhysX().getDefaultMaterial(), true);
  14. shape->setLocalPose(toPxTransform(position, rotation));
  15. shape->userData = this;
  16. mInternal = bs_new<FPhysXCollider>(shape);
  17. }
  18. PhysXBoxCollider::~PhysXBoxCollider()
  19. {
  20. bs_delete(mInternal);
  21. }
  22. void PhysXBoxCollider::setScale(const Vector3& scale)
  23. {
  24. BoxCollider::setScale(scale);
  25. applyGeometry();
  26. }
  27. void PhysXBoxCollider::setExtents(const Vector3& extents)
  28. {
  29. mExtents = extents;
  30. applyGeometry();
  31. }
  32. Vector3 PhysXBoxCollider::getExtents() const
  33. {
  34. return mExtents;
  35. }
  36. void PhysXBoxCollider::applyGeometry()
  37. {
  38. PxBoxGeometry geometry(mExtents.x * mScale.x, mExtents.y * mScale.y, mExtents.z * mScale.z);
  39. getInternal()->_getShape()->setGeometry(geometry);
  40. }
  41. FPhysXCollider* PhysXBoxCollider::getInternal() const
  42. {
  43. return static_cast<FPhysXCollider*>(mInternal);
  44. }
  45. }