mirror of
https://github.com/TorqueGameEngines/Torque3D.git
synced 2026-01-28 16:41:01 +00:00
167 lines
5.3 KiB
C++
167 lines
5.3 KiB
C++
//-----------------------------------------------------------------------------
|
|
// Copyright (c) 2012 GarageGames, LLC
|
|
//
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
// of this software and associated documentation files (the "Software"), to
|
|
// deal in the Software without restriction, including without limitation the
|
|
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
// sell copies of the Software, and to permit persons to whom the Software is
|
|
// furnished to do so, subject to the following conditions:
|
|
//
|
|
// The above copyright notice and this permission notice shall be included in
|
|
// all copies or substantial portions of the Software.
|
|
//
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
// IN THE SOFTWARE.
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#ifndef COLLISION_INTERFACES_H
|
|
#define COLLISION_INTERFACES_H
|
|
|
|
#ifndef _CONVEX_H_
|
|
#include "collision/convex.h"
|
|
#endif
|
|
#ifndef _COLLISION_H_
|
|
#include "collision/collision.h"
|
|
#endif
|
|
#ifndef _EARLYOUTPOLYLIST_H_
|
|
#include "collision/earlyOutPolyList.h"
|
|
#endif
|
|
#ifndef _SIM_H_
|
|
#include "console/sim.h"
|
|
#endif
|
|
#ifndef _SCENECONTAINER_H_
|
|
#include "scene/sceneContainer.h"
|
|
#endif
|
|
#ifndef _T3D_PHYSICSCOMMON_H_
|
|
#include "T3D/physics/physicsCommon.h"
|
|
#endif
|
|
|
|
struct ContactInfo
|
|
{
|
|
bool contacted, move;
|
|
SceneObject *contactObject;
|
|
VectorF idealContactNormal;
|
|
VectorF contactNormal;
|
|
Point3F contactPoint;
|
|
F32 contactTime;
|
|
S32 contactTimer;
|
|
BaseMatInstance *contactMaterial;
|
|
|
|
void clear()
|
|
{
|
|
contacted=move=false;
|
|
contactObject = NULL;
|
|
contactNormal.set(0,0,0);
|
|
contactTime = 0.f;
|
|
contactTimer = 0;
|
|
idealContactNormal.set(0, 0, 1);
|
|
contactMaterial = NULL;
|
|
}
|
|
|
|
ContactInfo() { clear(); }
|
|
|
|
};
|
|
|
|
class CollisionInterface// : public Interface<CollisionInterface>
|
|
{
|
|
public:
|
|
// CollisionTimeout
|
|
// This struct lets us track our collisions and estimate when they've have timed out and we'll need to act on it.
|
|
struct CollisionTimeout
|
|
{
|
|
CollisionTimeout* next;
|
|
SceneObject* object;
|
|
U32 objectNumber;
|
|
SimTime expireTime;
|
|
VectorF vector;
|
|
};
|
|
|
|
Signal< void( SceneObject* ) > onCollisionSignal;
|
|
Signal< void( SceneObject* ) > onContactSignal;
|
|
|
|
protected:
|
|
CollisionTimeout* mTimeoutList;
|
|
static CollisionTimeout* sFreeTimeoutList;
|
|
|
|
CollisionList mCollisionList;
|
|
Vector<CollisionInterface*> mCollisionNotifyList;
|
|
|
|
ContactInfo mContactInfo;
|
|
|
|
Box3F mWorkingQueryBox;
|
|
|
|
U32 CollisionMoveMask;
|
|
|
|
Convex *mConvexList;
|
|
|
|
bool mBlockColliding;
|
|
|
|
void handleCollisionNotifyList();
|
|
|
|
void queueCollision( SceneObject *obj, const VectorF &vec);
|
|
|
|
/// checkEarlyOut
|
|
/// This function lets you trying and early out of any expensive collision checks by using simple extruded poly boxes representing our objects
|
|
/// If it returns true, we know we won't hit with the given parameters and can successfully early out. If it returns false, our test case collided
|
|
/// and we should do the full collision sim.
|
|
bool checkEarlyOut(Point3F start, VectorF velocity, F32 time, Box3F objectBox, Point3F objectScale,
|
|
Box3F collisionBox, U32 collisionMask, CollisionWorkingList &colWorkingList);
|
|
|
|
public:
|
|
/// checkCollisions
|
|
// This is our main function for checking if a collision is happening based on the start point, velocity and time
|
|
// We do the bulk of the collision checking in here
|
|
//virtual bool checkCollisions( const F32 travelTime, Point3F *velocity, Point3F start )=0;
|
|
|
|
CollisionList *getCollisionList() { return &mCollisionList; }
|
|
|
|
void clearCollisionList() { mCollisionList.clear(); }
|
|
|
|
void clearCollisionNotifyList() { mCollisionNotifyList.clear(); }
|
|
|
|
Collision *getCollision(S32 col);
|
|
|
|
ContactInfo* getContactInfo() { return &mContactInfo; }
|
|
|
|
Convex *getConvexList() { return mConvexList; }
|
|
|
|
virtual bool buildPolyList(PolyListContext context, AbstractPolyList* polyList, const Box3F &box, const SphereF &sphere) = 0;
|
|
|
|
enum PublicConstants {
|
|
CollisionTimeoutValue = 250
|
|
};
|
|
|
|
bool doesBlockColliding() { return mBlockColliding; }
|
|
|
|
/// handleCollisionList
|
|
/// This basically takes in a CollisionList and calls handleCollision for each.
|
|
void handleCollisionList(CollisionList &collisionList, VectorF velocity);
|
|
|
|
/// handleCollision
|
|
/// This will take a collision and queue the collision info for the object so that in knows about the collision.
|
|
void handleCollision(Collision &col, VectorF velocity);
|
|
|
|
virtual PhysicsCollision* getCollisionData() = 0;
|
|
|
|
Signal< void(PhysicsCollision* collision) > onCollisionChanged;
|
|
};
|
|
|
|
class BuildConvexInterface //: public Interface<CollisionInterface>
|
|
{
|
|
public:
|
|
virtual void buildConvex(const Box3F& box, Convex* convex)=0;
|
|
};
|
|
|
|
class BuildPolyListInterface// : public Interface<CollisionInterface>
|
|
{
|
|
public:
|
|
virtual bool buildPolyList(PolyListContext context, AbstractPolyList* polyList, const Box3F &box, const SphereF &sphere) = 0;
|
|
};
|
|
|
|
#endif |