diff --git a/apps/openmw/mwphysics/contacttestresultcallback.cpp b/apps/openmw/mwphysics/contacttestresultcallback.cpp new file mode 100644 index 000000000..f8209e363 --- /dev/null +++ b/apps/openmw/mwphysics/contacttestresultcallback.cpp @@ -0,0 +1,27 @@ +#include "contacttestresultcallback.hpp" + +#include + +#include "ptrholder.hpp" + +namespace MWPhysics +{ + ContactTestResultCallback::ContactTestResultCallback(const btCollisionObject* testedAgainst) + : mTestedAgainst(testedAgainst) + { + } + + btScalar ContactTestResultCallback::addSingleResult(btManifoldPoint& cp, + const btCollisionObjectWrapper* col0Wrap,int partId0,int index0, + const btCollisionObjectWrapper* col1Wrap,int partId1,int index1) + { + const btCollisionObject* collisionObject = col0Wrap->m_collisionObject; + if (collisionObject == mTestedAgainst) + collisionObject = col1Wrap->m_collisionObject; + PtrHolder* holder = static_cast(collisionObject->getUserPointer()); + if (holder) + mResult.push_back(holder->getPtr()); + return 0.f; + } + +} diff --git a/apps/openmw/mwphysics/contacttestresultcallback.hpp b/apps/openmw/mwphysics/contacttestresultcallback.hpp new file mode 100644 index 000000000..bb90eced0 --- /dev/null +++ b/apps/openmw/mwphysics/contacttestresultcallback.hpp @@ -0,0 +1,30 @@ +#ifndef OPENMW_MWPHYSICS_CONTACTTESTRESULTCALLBACK_H +#define OPENMW_MWPHYSICS_CONTACTTESTRESULTCALLBACK_H + +#include + +#include + +#include "../mwworld/ptr.hpp" + +class btCollisionObject; +class btCollisionObjectWrapper; + +namespace MWPhysics +{ + class ContactTestResultCallback : public btCollisionWorld::ContactResultCallback + { + const btCollisionObject* mTestedAgainst; + + public: + ContactTestResultCallback(const btCollisionObject* testedAgainst); + + virtual btScalar addSingleResult(btManifoldPoint& cp, + const btCollisionObjectWrapper* col0Wrap,int partId0,int index0, + const btCollisionObjectWrapper* col1Wrap,int partId1,int index1); + + std::vector mResult; + }; +} + +#endif diff --git a/apps/openmw/mwphysics/physicssystem.cpp b/apps/openmw/mwphysics/physicssystem.cpp index 73284cd7f..bf4bd386e 100644 --- a/apps/openmw/mwphysics/physicssystem.cpp +++ b/apps/openmw/mwphysics/physicssystem.cpp @@ -48,6 +48,7 @@ #include "hasspherecollisioncallback.hpp" #include "deepestnotmecontacttestresultcallback.hpp" #include "closestnotmerayresultcallback.hpp" +#include "contacttestresultcallback.hpp" namespace MWPhysics { @@ -882,32 +883,6 @@ namespace MWPhysics return osg::Vec3f(); } - class ContactTestResultCallback : public btCollisionWorld::ContactResultCallback - { - public: - ContactTestResultCallback(const btCollisionObject* testedAgainst) - : mTestedAgainst(testedAgainst) - { - } - - const btCollisionObject* mTestedAgainst; - - std::vector mResult; - - virtual btScalar addSingleResult(btManifoldPoint& cp, - const btCollisionObjectWrapper* col0Wrap,int partId0,int index0, - const btCollisionObjectWrapper* col1Wrap,int partId1,int index1) - { - const btCollisionObject* collisionObject = col0Wrap->m_collisionObject; - if (collisionObject == mTestedAgainst) - collisionObject = col1Wrap->m_collisionObject; - PtrHolder* holder = static_cast(collisionObject->getUserPointer()); - if (holder) - mResult.push_back(holder->getPtr()); - return 0.f; - } - }; - std::vector PhysicsSystem::getCollisions(const MWWorld::ConstPtr &ptr, int collisionGroup, int collisionMask) const { btCollisionObject* me = nullptr;