Bullet Collision Detection & Physics Library
btCapsuleShape.h
Go to the documentation of this file.
1 /*
2 Bullet Continuous Collision Detection and Physics Library
3 Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org
4 
5 This software is provided 'as-is', without any express or implied warranty.
6 In no event will the authors be held liable for any damages arising from the use of this software.
7 Permission is granted to anyone to use this software for any purpose,
8 including commercial applications, and to alter it and redistribute it freely,
9 subject to the following restrictions:
10 
11 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.
12 2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
13 3. This notice may not be removed or altered from any source distribution.
14 */
15 
16 #ifndef BT_CAPSULE_SHAPE_H
17 #define BT_CAPSULE_SHAPE_H
18 
19 #include "btConvexInternalShape.h"
21 
22 
27 {
28 protected:
29  int m_upAxis;
30 
31 protected:
33  btCapsuleShape() : btConvexInternalShape() {m_shapeType = CAPSULE_SHAPE_PROXYTYPE;};
34 
35 public:
36 
38 
39  btCapsuleShape(btScalar radius,btScalar height);
40 
42  virtual void calculateLocalInertia(btScalar mass,btVector3& inertia) const;
43 
45  virtual btVector3 localGetSupportingVertexWithoutMargin(const btVector3& vec)const;
46 
47  virtual void batchedUnitVectorGetSupportingVertexWithoutMargin(const btVector3* vectors,btVector3* supportVerticesOut,int numVectors) const;
48 
49  virtual void setMargin(btScalar collisionMargin)
50  {
51  //correct the m_implicitShapeDimensions for the margin
52  btVector3 oldMargin(getMargin(),getMargin(),getMargin());
53  btVector3 implicitShapeDimensionsWithMargin = m_implicitShapeDimensions+oldMargin;
54 
55  btConvexInternalShape::setMargin(collisionMargin);
56  btVector3 newMargin(getMargin(),getMargin(),getMargin());
57  m_implicitShapeDimensions = implicitShapeDimensionsWithMargin - newMargin;
58 
59  }
60 
61  virtual void getAabb (const btTransform& t, btVector3& aabbMin, btVector3& aabbMax) const
62  {
63  btVector3 halfExtents(getRadius(),getRadius(),getRadius());
64  halfExtents[m_upAxis] = getRadius() + getHalfHeight();
65  halfExtents += btVector3(getMargin(),getMargin(),getMargin());
66  btMatrix3x3 abs_b = t.getBasis().absolute();
67  btVector3 center = t.getOrigin();
68  btVector3 extent = halfExtents.dot3(abs_b[0], abs_b[1], abs_b[2]);
69 
70  aabbMin = center - extent;
71  aabbMax = center + extent;
72  }
73 
74  virtual const char* getName()const
75  {
76  return "CapsuleShape";
77  }
78 
79  int getUpAxis() const
80  {
81  return m_upAxis;
82  }
83 
85  {
86  int radiusAxis = (m_upAxis+2)%3;
87  return m_implicitShapeDimensions[radiusAxis];
88  }
89 
91  {
92  return m_implicitShapeDimensions[m_upAxis];
93  }
94 
95  virtual void setLocalScaling(const btVector3& scaling)
96  {
97  btVector3 oldMargin(getMargin(),getMargin(),getMargin());
98  btVector3 implicitShapeDimensionsWithMargin = m_implicitShapeDimensions+oldMargin;
99  btVector3 unScaledImplicitShapeDimensionsWithMargin = implicitShapeDimensionsWithMargin / m_localScaling;
100 
102 
103  m_implicitShapeDimensions = (unScaledImplicitShapeDimensionsWithMargin * m_localScaling) - oldMargin;
104 
105  }
106 
108  {
109  btVector3 aniDir(0,0,0);
110  aniDir[getUpAxis()]=1;
111  return aniDir;
112  }
113 
114 
115  virtual int calculateSerializeBufferSize() const;
116 
118  virtual const char* serialize(void* dataBuffer, btSerializer* serializer) const;
119 
120 
121 };
122 
126 {
127 public:
128 
129  btCapsuleShapeX(btScalar radius,btScalar height);
130 
131  //debugging
132  virtual const char* getName()const
133  {
134  return "CapsuleX";
135  }
136 
137 
138 
139 };
140 
144 {
145 public:
146  btCapsuleShapeZ(btScalar radius,btScalar height);
147 
148  //debugging
149  virtual const char* getName()const
150  {
151  return "CapsuleZ";
152  }
153 
154 
155 };
156 
159 {
161 
162  int m_upAxis;
163 
164  char m_padding[4];
165 };
166 
168 {
169  return sizeof(btCapsuleShapeData);
170 }
171 
173 SIMD_FORCE_INLINE const char* btCapsuleShape::serialize(void* dataBuffer, btSerializer* serializer) const
174 {
175  btCapsuleShapeData* shapeData = (btCapsuleShapeData*) dataBuffer;
176 
178 
179  shapeData->m_upAxis = m_upAxis;
180 
181  return "btCapsuleShapeData";
182 }
183 
184 #endif //BT_CAPSULE_SHAPE_H