2010-09-09 22:27:01 +00:00
|
|
|
|
/********************************************************************************
|
|
|
|
|
* ReactPhysics3D physics library, http://code.google.com/p/reactphysics3d/ *
|
|
|
|
|
* Copyright (c) 2010 Daniel Chappuis *
|
|
|
|
|
*********************************************************************************
|
|
|
|
|
* *
|
|
|
|
|
* 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 RIGIDBODY_H
|
|
|
|
|
#define RIGIDBODY_H
|
|
|
|
|
|
|
|
|
|
// Libraries
|
|
|
|
|
#include <cassert>
|
|
|
|
|
#include "Body.h"
|
2011-07-10 17:56:00 +00:00
|
|
|
|
#include "../shapes/Shape.h"
|
2010-09-09 22:27:01 +00:00
|
|
|
|
#include "../mathematics/mathematics.h"
|
|
|
|
|
|
|
|
|
|
// Namespace reactphysics3d
|
|
|
|
|
namespace reactphysics3d {
|
|
|
|
|
|
|
|
|
|
/* -------------------------------------------------------------------
|
|
|
|
|
Class RigidBody :
|
|
|
|
|
This class represents a rigid body of the physics
|
|
|
|
|
engine. A rigid body is a non-deformable body that
|
|
|
|
|
has a constant mass.
|
|
|
|
|
-------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
class RigidBody : public Body {
|
|
|
|
|
protected :
|
2011-10-18 22:03:05 +00:00
|
|
|
|
Vector3 linearVelocity; // Linear velocity of the body
|
|
|
|
|
Vector3 angularVelocity; // Angular velocity of the body
|
|
|
|
|
Vector3 externalForce; // Current external force on the body
|
|
|
|
|
Vector3 externalTorque; // Current external torque on the body
|
|
|
|
|
Matrix3x3 inertiaTensorLocal; // Local inertia tensor of the body (in body coordinates)
|
|
|
|
|
Matrix3x3 inertiaTensorLocalInverse; // Inverse of the inertia tensor of the body (in body coordinates)
|
|
|
|
|
double massInverse; // Inverse of the mass of the body
|
|
|
|
|
double restitution; // Coefficient of restitution (between 0 and 1), 1 for a very boucing body
|
2010-09-09 22:27:01 +00:00
|
|
|
|
|
|
|
|
|
public :
|
2011-10-18 22:03:05 +00:00
|
|
|
|
RigidBody(const Transform& transform, double mass, const Matrix3x3& inertiaTensorLocal,
|
|
|
|
|
Shape* shape, long unsigned int id); // Constructor // Copy-constructor
|
|
|
|
|
virtual ~RigidBody(); // Destructor
|
2010-09-09 22:27:01 +00:00
|
|
|
|
|
2011-08-18 21:02:48 +00:00
|
|
|
|
Vector3 getLinearVelocity() const; // Return the linear velocity
|
|
|
|
|
void setLinearVelocity(const Vector3& linearVelocity); // Set the linear velocity of the body
|
|
|
|
|
Vector3 getAngularVelocity() const; // Return the angular velocity
|
|
|
|
|
void setAngularVelocity(const Vector3& angularVelocity); // Set the angular velocity
|
2010-09-09 22:27:01 +00:00
|
|
|
|
void setMassInverse(double massInverse); // Set the inverse of the mass
|
2011-08-18 21:02:48 +00:00
|
|
|
|
Vector3 getExternalForce() const; // Return the current external force of the body
|
|
|
|
|
void setExternalForce(const Vector3& force); // Set the current external force on the body
|
|
|
|
|
Vector3 getExternalTorque() const; // Return the current external torque of the body
|
|
|
|
|
void setExternalTorque(const Vector3& torque); // Set the current external torque of the body
|
2010-09-09 22:27:01 +00:00
|
|
|
|
double getMassInverse() const; // Return the inverse of the mass of the body
|
|
|
|
|
Matrix3x3 getInertiaTensorLocal() const; // Return the local inertia tensor of the body (in body coordinates)
|
|
|
|
|
void setInertiaTensorLocal(const Matrix3x3& inertiaTensorLocal); // Set the local inertia tensor of the body (in body coordinates)
|
|
|
|
|
Matrix3x3 getInertiaTensorLocalInverse() const; // Get the inverse of the inertia tensor
|
|
|
|
|
Matrix3x3 getInertiaTensorWorld() const; // Return the inertia tensor in world coordinates
|
|
|
|
|
Matrix3x3 getInertiaTensorInverseWorld() const; // Return the inverse of the inertia tensor in world coordinates
|
2011-06-30 20:23:01 +00:00
|
|
|
|
|
2010-09-09 22:27:01 +00:00
|
|
|
|
double getRestitution() const; // Get the restitution coefficient
|
|
|
|
|
void setRestitution(double restitution) throw(std::invalid_argument); // Set the restitution coefficient
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Return the linear velocity
|
2011-08-18 21:02:48 +00:00
|
|
|
|
inline Vector3 RigidBody::getLinearVelocity() const {
|
2010-09-09 22:27:01 +00:00
|
|
|
|
return linearVelocity;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Return the angular velocity of the body
|
2011-08-18 21:02:48 +00:00
|
|
|
|
inline Vector3 RigidBody::getAngularVelocity() const {
|
2010-09-09 22:27:01 +00:00
|
|
|
|
return angularVelocity;
|
|
|
|
|
}
|
|
|
|
|
|
2011-08-18 21:02:48 +00:00
|
|
|
|
inline void RigidBody::setAngularVelocity(const Vector3& angularVelocity) {
|
2010-09-09 22:27:01 +00:00
|
|
|
|
this->angularVelocity = angularVelocity;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Set the inverse of the mass
|
|
|
|
|
inline void RigidBody::setMassInverse(double massInverse) {
|
|
|
|
|
this->massInverse = massInverse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get the inverse of the inertia tensor
|
|
|
|
|
inline Matrix3x3 RigidBody::getInertiaTensorLocalInverse() const {
|
|
|
|
|
return inertiaTensorLocalInverse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Return the external force on the body
|
2011-08-18 21:02:48 +00:00
|
|
|
|
inline Vector3 RigidBody::getExternalForce() const {
|
2010-09-09 22:27:01 +00:00
|
|
|
|
return externalForce;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Set the external force on the body
|
2011-08-18 21:02:48 +00:00
|
|
|
|
inline void RigidBody::setExternalForce(const Vector3& force) {
|
2010-09-09 22:27:01 +00:00
|
|
|
|
this->externalForce = force;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Return the current external torque on the body
|
2011-08-18 21:02:48 +00:00
|
|
|
|
inline Vector3 RigidBody::getExternalTorque() const {
|
2010-09-09 22:27:01 +00:00
|
|
|
|
return externalTorque;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Set the current external torque on the body
|
2011-08-18 21:02:48 +00:00
|
|
|
|
inline void RigidBody::setExternalTorque(const Vector3& torque) {
|
2010-09-09 22:27:01 +00:00
|
|
|
|
this->externalTorque = torque;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Return the inverse of the mass of the body
|
|
|
|
|
inline double RigidBody::getMassInverse() const {
|
|
|
|
|
return massInverse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Return the local inertia tensor of the body (in body coordinates)
|
|
|
|
|
inline Matrix3x3 RigidBody::getInertiaTensorLocal() const {
|
|
|
|
|
return inertiaTensorLocal;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Set the local inertia tensor of the body (in body coordinates)
|
|
|
|
|
inline void RigidBody::setInertiaTensorLocal(const Matrix3x3& inertiaTensorLocal) {
|
|
|
|
|
this->inertiaTensorLocal = inertiaTensorLocal;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Return the inertia tensor in world coordinates
|
|
|
|
|
// The inertia tensor I_w in world coordinates in computed with the local inertia tensor I_b in body coordinates
|
|
|
|
|
// by I_w = R * I_b * R^T
|
|
|
|
|
// where R is the rotation matrix (and R^T its transpose) of the current orientation quaternion of the body
|
|
|
|
|
inline Matrix3x3 RigidBody::getInertiaTensorWorld() const {
|
|
|
|
|
// Compute and return the inertia tensor in world coordinates
|
2011-08-08 21:41:07 +00:00
|
|
|
|
return transform.getOrientation().getMatrix() * inertiaTensorLocal * transform.getOrientation().getMatrix().getTranspose();
|
2010-09-09 22:27:01 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Return the inverse of the inertia tensor in world coordinates
|
|
|
|
|
// The inertia tensor I_w in world coordinates in computed with the local inverse inertia tensor I_b^-1 in body coordinates
|
|
|
|
|
// by I_w = R * I_b^-1 * R^T
|
|
|
|
|
// where R is the rotation matrix (and R^T its transpose) of the current orientation quaternion of the body
|
|
|
|
|
inline Matrix3x3 RigidBody::getInertiaTensorInverseWorld() const {
|
|
|
|
|
// Compute and return the inertia tensor in world coordinates
|
2011-08-08 21:41:07 +00:00
|
|
|
|
return transform.getOrientation().getMatrix() * inertiaTensorLocalInverse * transform.getOrientation().getMatrix().getTranspose();
|
2010-09-09 22:27:01 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Set the linear velocity of the rigid body
|
2011-08-18 21:02:48 +00:00
|
|
|
|
inline void RigidBody::setLinearVelocity(const Vector3& linearVelocity) {
|
2010-09-09 22:27:01 +00:00
|
|
|
|
// If the body is able to move
|
|
|
|
|
if (isMotionEnabled) {
|
|
|
|
|
// Update the linear velocity of the current body state
|
|
|
|
|
this->linearVelocity = linearVelocity;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get the restitution coeffficient of the rigid body
|
|
|
|
|
inline double RigidBody::getRestitution() const {
|
|
|
|
|
return restitution;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Set the restitution coefficient
|
|
|
|
|
inline void RigidBody::setRestitution(double restitution) throw(std::invalid_argument) {
|
|
|
|
|
// Check if the restitution coefficient is between 0 and 1
|
|
|
|
|
if (restitution >= 0.0 && restitution <= 1.0) {
|
|
|
|
|
this->restitution = restitution;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
throw std::invalid_argument("Error : the restitution coefficent must be between 0 and 1");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} // End of the ReactPhyscis3D namespace
|
|
|
|
|
|
|
|
|
|
#endif
|