| Bullet Collision Detection & Physics Library
    | 
 
 
 
Go to the documentation of this file.
   51 #ifndef USE_BOX_INERTIA_APPROXIMATION 
   68         int idxRadius, idxHeight;
 
   86         radius2 = halfExtents[idxRadius] * halfExtents[idxRadius];
 
   87         height2 = 
btScalar(4.) * halfExtents[idxHeight] * halfExtents[idxHeight];
 
   90         btScalar t1 = div12 * height2 + div4 * radius2;
 
  104 #else   //USE_BOX_INERTIA_APPROXIMATION 
  113                                          mass / (
btScalar(12.0)) * (lx * lx + lz * lz),
 
  114                                          mass / (
btScalar(12.0)) * (lx * lx + ly * ly));
 
  115 #endif  //USE_BOX_INERTIA_APPROXIMATION 
  120         const int cylinderUpAxis = 0;
 
  129         btScalar halfHeight = halfExtents[cylinderUpAxis];
 
  139                 tmp[YY] = v[YY] < 0.0 ? -halfHeight : halfHeight;
 
  146                 tmp[YY] = v[YY] < 0.0 ? -halfHeight : halfHeight;
 
  154         const int cylinderUpAxis = 1;
 
  160         btScalar halfHeight = halfExtents[cylinderUpAxis];
 
  170                 tmp[YY] = v[YY] < 0.0 ? -halfHeight : halfHeight;
 
  177                 tmp[YY] = v[YY] < 0.0 ? -halfHeight : halfHeight;
 
  185         const int cylinderUpAxis = 2;
 
  194         btScalar halfHeight = halfExtents[cylinderUpAxis];
 
  204                 tmp[YY] = v[YY] < 0.0 ? -halfHeight : halfHeight;
 
  211                 tmp[YY] = v[YY] < 0.0 ? -halfHeight : halfHeight;
 
  233         for (
int i = 0; i < numVectors; i++)
 
  241         for (
int i = 0; i < numVectors; i++)
 
  249         for (
int i = 0; i < numVectors; i++)
 
  
The btConvexInternalShape is an internal base class, shared by most convex shape implementations.
void setValue(const btScalar &_x, const btScalar &_y, const btScalar &_z)
float btScalar
The btScalar type abstracts floating point numbers, to easily switch between double and single floati...
btVector3 getHalfExtentsWithMargin() const
btCylinderShapeX(const btVector3 &halfExtents)
virtual btVector3 localGetSupportingVertexWithoutMargin(const btVector3 &vec) const
btVector3 CylinderLocalSupportZ(const btVector3 &halfExtents, const btVector3 &v)
virtual btVector3 localGetSupportingVertexWithoutMargin(const btVector3 &vec) const
virtual btVector3 localGetSupportingVertexWithoutMargin(const btVector3 &vec) const
const btScalar & y() const
Return the y value.
btCylinderShape(const btVector3 &halfExtents)
const btVector3 & getHalfExtentsWithoutMargin() const
btVector3 m_implicitShapeDimensions
btCylinderShapeZ(const btVector3 &halfExtents)
btVector3 can be used to represent 3D points and vectors.
void setSafeMargin(btScalar minDimension, btScalar defaultMarginMultiplier=0.1f)
virtual void calculateLocalInertia(btScalar mass, btVector3 &inertia) const
virtual btScalar getMargin() const
btVector3 CylinderLocalSupportX(const btVector3 &halfExtents, const btVector3 &v)
#define SIMD_FORCE_INLINE
const btScalar & x() const
Return the x value.
void btTransformAabb(const btVector3 &halfExtents, btScalar margin, const btTransform &t, btVector3 &aabbMinOut, btVector3 &aabbMaxOut)
virtual void batchedUnitVectorGetSupportingVertexWithoutMargin(const btVector3 *vectors, btVector3 *supportVerticesOut, int numVectors) const
The btCylinderShape class implements a cylinder shape primitive, centered around the origin....
void getAabb(const btTransform &t, btVector3 &aabbMin, btVector3 &aabbMax) const
getAabb's default implementation is brute force, expected derived classes to implement a fast dedicat...
btScalar btSqrt(btScalar y)
virtual void batchedUnitVectorGetSupportingVertexWithoutMargin(const btVector3 *vectors, btVector3 *supportVerticesOut, int numVectors) const
virtual void batchedUnitVectorGetSupportingVertexWithoutMargin(const btVector3 *vectors, btVector3 *supportVerticesOut, int numVectors) const
const btScalar & z() const
Return the z value.
btVector3 CylinderLocalSupportY(const btVector3 &halfExtents, const btVector3 &v)