2020-03-30 18:39:10 +00:00
|
|
|
#include "deepestnotmecontacttestresultcallback.hpp"
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
|
2020-03-30 21:25:33 +00:00
|
|
|
#include <BulletCollision/CollisionDispatch/btCollisionObject.h>
|
|
|
|
|
2021-08-05 08:55:19 +00:00
|
|
|
#include "collisiontype.hpp"
|
2020-03-30 18:39:10 +00:00
|
|
|
|
|
|
|
namespace MWPhysics
|
|
|
|
{
|
|
|
|
|
|
|
|
DeepestNotMeContactTestResultCallback::DeepestNotMeContactTestResultCallback(
|
|
|
|
const btCollisionObject* me, const std::vector<const btCollisionObject*>& targets, const btVector3& origin)
|
|
|
|
: mMe(me)
|
|
|
|
, mTargets(targets)
|
|
|
|
, mOrigin(origin)
|
|
|
|
, mLeastDistSqr(std::numeric_limits<float>::max())
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
btScalar DeepestNotMeContactTestResultCallback::addSingleResult(btManifoldPoint& cp,
|
|
|
|
const btCollisionObjectWrapper* col0Wrap, int partId0, int index0, const btCollisionObjectWrapper* col1Wrap,
|
|
|
|
int partId1, int index1)
|
|
|
|
{
|
|
|
|
const btCollisionObject* collisionObject = col1Wrap->m_collisionObject;
|
|
|
|
if (collisionObject != mMe)
|
|
|
|
{
|
2021-08-05 08:55:19 +00:00
|
|
|
if (collisionObject->getBroadphaseHandle()->m_collisionFilterGroup == CollisionType_Actor
|
|
|
|
&& !mTargets.empty())
|
2020-03-30 18:39:10 +00:00
|
|
|
{
|
|
|
|
if ((std::find(mTargets.begin(), mTargets.end(), collisionObject) == mTargets.end()))
|
2021-08-05 08:55:19 +00:00
|
|
|
return 0.f;
|
2020-03-30 18:39:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
btScalar distsqr = mOrigin.distance2(cp.getPositionWorldOnA());
|
|
|
|
if (!mObject || distsqr < mLeastDistSqr)
|
|
|
|
{
|
|
|
|
mObject = collisionObject;
|
|
|
|
mLeastDistSqr = distsqr;
|
|
|
|
mContactPoint = cp.getPositionWorldOnA();
|
2020-10-26 12:40:56 +00:00
|
|
|
mContactNormal = cp.m_normalWorldOnB;
|
2020-03-30 18:39:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0.f;
|
|
|
|
}
|
|
|
|
}
|