reactphysics3d/src/body/CollisionBody.h

248 lines
8.7 KiB
C
Raw Normal View History

2012-09-18 20:09:49 +00:00
/********************************************************************************
* ReactPhysics3D physics library, http://code.google.com/p/reactphysics3d/ *
* Copyright (c) 2010-2013 Daniel Chappuis *
2012-09-18 20:09:49 +00:00
*********************************************************************************
* *
* This software is provided 'as-is', without any express or implied warranty. *
* In no event will the authors be held liable for any damages arising from the *
* use of this software. *
* *
* Permission is granted to anyone to use this software for any purpose, *
* including commercial applications, and to alter it and redistribute it *
* freely, subject to the following restrictions: *
* *
* 1. The origin of this software must not be misrepresented; you must not claim *
* that you wrote the original software. If you use this software in a *
* product, an acknowledgment in the product documentation would be *
* appreciated but is not required. *
* *
* 2. Altered source versions must be plainly marked as such, and must not be *
* misrepresented as being the original software. *
* *
* 3. This notice may not be removed or altered from any source distribution. *
* *
********************************************************************************/
#ifndef REACTPHYSICS3D_COLLISION_BODY_H
#define REACTPHYSICS3D_COLLISION_BODY_H
2012-09-18 20:09:49 +00:00
// Libraries
#include <stdexcept>
#include <cassert>
#include "Body.h"
#include "../mathematics/Transform.h"
#include "../collision/shapes/AABB.h"
#include "../collision/shapes/CollisionShape.h"
2013-08-26 19:28:48 +00:00
#include "../memory/MemoryAllocator.h"
2012-09-18 20:09:49 +00:00
#include "../configuration.h"
/// Namespace reactphysics3d
2012-09-18 20:09:49 +00:00
namespace reactphysics3d {
2013-08-26 19:28:48 +00:00
// Class declarations
struct ContactManifoldListElement;
/// Enumeration for the type of a body
/// STATIC : A static body has infinite mass, zero velocity but the position can be
/// changed manually. A static body does not collide with other static or kinematic bodies.
/// KINEMATIC : A kinematic body has infinite mass, the velocity can be changed manually and its
/// position is computed by the physics engine. A kinematic body does not collide with
/// other static or kinematic bodies.
/// DYNAMIC : A dynamic body has non-zero mass, non-zero velocity determined by forces and its
/// position is determined by the physics engine. A dynamic body can collide with other
/// dynamic, static or kinematic bodies.
enum BodyType {STATIC, KINEMATIC, DYNAMIC};
// Class CollisionBody
/**
* This class represents a body that is able to collide with others
* bodies. This class inherits from the Body class.
*/
2012-09-18 20:09:49 +00:00
class CollisionBody : public Body {
protected :
// -------------------- Attributes -------------------- //
/// Type of body (static, kinematic or dynamic)
BodyType mType;
/// Collision shape of the body
CollisionShape* mCollisionShape;
/// Position and orientation of the body
Transform mTransform;
/// Last position and orientation of the body
Transform mOldTransform;
/// Interpolation factor used for the state interpolation
decimal mInterpolationFactor;
/// True if the body can collide with others bodies
bool mIsCollisionEnabled;
/// AABB for Broad-Phase collision detection
AABB mAabb;
/// True if the body has moved during the last frame
bool mHasMoved;
2013-08-26 19:28:48 +00:00
/// First element of the linked list of contact manifolds involving this body
ContactManifoldListElement* mContactManifoldsList;
// -------------------- Methods -------------------- //
/// Private copy-constructor
CollisionBody(const CollisionBody& body);
/// Private assignment operator
CollisionBody& operator=(const CollisionBody& body);
2012-09-18 20:09:49 +00:00
2013-08-26 19:28:48 +00:00
/// Reset the contact manifold lists
void resetContactManifoldsList(MemoryAllocator& memoryAllocator);
/// Update the old transform with the current one.
void updateOldTransform();
/// Update the Axis-Aligned Bounding Box coordinates
void updateAABB();
2012-09-18 20:09:49 +00:00
public :
// -------------------- Methods -------------------- //
/// Constructor
CollisionBody(const Transform& transform, CollisionShape* collisionShape, bodyindex id);
/// Destructor
virtual ~CollisionBody();
/// Return the type of the body
BodyType getType() const;
/// Set the type of the body
void setType(BodyType type);
/// Return the collision shape
CollisionShape* getCollisionShape() const;
/// Set the collision shape
void setCollisionShape(CollisionShape* collisionShape);
/// Return the current position and orientation
const Transform& getTransform() const;
/// Set the current position and orientation
void setTransform(const Transform& transform);
/// Return the AAABB of the body
const AABB& getAABB() const;
/// Return the interpolated transform for rendering
Transform getInterpolatedTransform() const;
/// Set the interpolation factor of the body
void setInterpolationFactor(decimal factor);
/// Return true if the body can collide with others bodies
bool isCollisionEnabled() const;
/// Enable/disable the collision with this body
void enableCollision(bool isCollisionEnabled);
2013-08-26 19:28:48 +00:00
/// Return the first element of the linked list of contact manifolds involving this body
const ContactManifoldListElement* getContactManifoldsLists() const;
// -------------------- Friendship -------------------- //
friend class DynamicsWorld;
friend class CollisionDetection;
2012-09-18 20:09:49 +00:00
};
// Return the type of the body
inline BodyType CollisionBody::getType() const {
return mType;
}
// Set the type of the body
inline void CollisionBody::setType(BodyType type) {
mType = type;
}
2012-09-18 20:09:49 +00:00
// Return the collision shape
inline CollisionShape* CollisionBody::getCollisionShape() const {
assert(mCollisionShape);
return mCollisionShape;
2012-09-18 20:09:49 +00:00
}
// Set the collision shape
inline void CollisionBody::setCollisionShape(CollisionShape* collisionShape) {
assert(collisionShape);
mCollisionShape = collisionShape;
2012-09-18 20:09:49 +00:00
}
// Return the interpolated transform for rendering
inline Transform CollisionBody::getInterpolatedTransform() const {
return Transform::interpolateTransforms(mOldTransform, mTransform, mInterpolationFactor);
2012-09-18 20:09:49 +00:00
}
// Set the interpolation factor of the body
inline void CollisionBody::setInterpolationFactor(decimal factor) {
// Set the factor
mInterpolationFactor = factor;
2012-09-18 20:09:49 +00:00
}
// Return the current position and orientation
inline const Transform& CollisionBody::getTransform() const {
return mTransform;
2012-09-18 20:09:49 +00:00
}
// Set the current position and orientation
inline void CollisionBody::setTransform(const Transform& transform) {
// Check if the body has moved
2013-06-12 18:43:54 +00:00
if (mTransform != transform) {
mHasMoved = true;
2012-09-18 20:09:49 +00:00
}
mTransform = transform;
2012-09-18 20:09:49 +00:00
}
// Return the AAABB of the body
inline const AABB& CollisionBody::getAABB() const {
return mAabb;
2012-09-18 20:09:49 +00:00
}
// Return true if the body can collide with others bodies
inline bool CollisionBody::isCollisionEnabled() const {
return mIsCollisionEnabled;
2012-09-18 20:09:49 +00:00
}
// Enable/disable the collision with this body
inline void CollisionBody::enableCollision(bool isCollisionEnabled) {
mIsCollisionEnabled = isCollisionEnabled;
2012-09-18 20:09:49 +00:00
}
// Update the old transform with the current one.
/// This is used to compute the interpolated position and orientation of the body
2012-09-18 20:09:49 +00:00
inline void CollisionBody::updateOldTransform() {
mOldTransform = mTransform;
2012-09-18 20:09:49 +00:00
}
// Update the rigid body in order to reflect a change in the body state
inline void CollisionBody::updateAABB() {
// Update the AABB
mCollisionShape->updateAABB(mAabb, mTransform);
2012-09-18 20:09:49 +00:00
}
2013-08-26 19:28:48 +00:00
// Return the first element of the linked list of contact manifolds involving this body
inline const ContactManifoldListElement* CollisionBody::getContactManifoldsLists() const {
return mContactManifoldsList;
}
2012-09-18 20:09:49 +00:00
}
#endif