Bullet Collision Detection & Physics Library
btContinuousConvexCollision.cpp
Go to the documentation of this file.
1/*
2Bullet Continuous Collision Detection and Physics Library
3Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
4
5This software is provided 'as-is', without any express or implied warranty.
6In no event will the authors be held liable for any damages arising from the use of this software.
7Permission is granted to anyone to use this software for any purpose,
8including commercial applications, and to alter it and redistribute it freely,
9subject to the following restrictions:
10
111. 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.
122. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
133. This notice may not be removed or altered from any source distribution.
14*/
15
16
22
23#include "btGjkPairDetector.h"
24#include "btPointCollector.h"
26
27
28
30:m_simplexSolver(simplexSolver),
31m_penetrationDepthSolver(penetrationDepthSolver),
32m_convexA(convexA),m_convexB1(convexB),m_planeShape(0)
33{
34}
35
36
38:m_simplexSolver(0),
39m_penetrationDepthSolver(0),
40m_convexA(convexA),m_convexB1(0),m_planeShape(plane)
41{
42}
43
44
47#define MAX_ITERATIONS 64
48
50{
51 if (m_convexB1)
52 {
53 m_simplexSolver->reset();
57 input.m_transformB = transB;
58 gjk.getClosestPoints(input,pointCollector,0);
59 } else
60 {
61 //convex versus plane
64
65 const btVector3& planeNormal = planeShape->getPlaneNormal();
66 const btScalar& planeConstant = planeShape->getPlaneConstant();
67
73
74 btVector3 vtx = convexShape->localGetSupportingVertex(planeInConvex.getBasis()*-planeNormal);
75
77 btScalar distance = (planeNormal.dot(vtxInPlane) - planeConstant);
78
82
83 pointCollector.addContactPoint(
86 distance);
87 }
88}
89
91 const btTransform& fromA,
92 const btTransform& toA,
93 const btTransform& fromB,
94 const btTransform& toB,
96{
97
98
103
104
107
110
112
114 return false;
115
116
117
119 btVector3 v(1,0,0);
120
122
123 btVector3 n;
124 n.setValue(btScalar(0.),btScalar(0.),btScalar(0.));
125 bool hasResult = false;
126 btVector3 c;
127
129 //btScalar epsilon = btScalar(0.001);
130
131 int numIter = 0;
132 //first solution, using GJK
133
134
135 btScalar radius = 0.001f;
136// result.drawCoordSystem(sphereTr);
137
139
140 {
141
143
144 hasResult = pointCollector1.m_hasResult;
145 c = pointCollector1.m_pointInWorld;
146 }
147
148 if (hasResult)
149 {
150 btScalar dist;
151 dist = pointCollector1.m_distance + result.m_allowedPenetration;
152 n = pointCollector1.m_normalOnBInWorld;
155 return false;
156
157 //not close enough
158 while (dist > radius)
159 {
160 if (result.m_debugDrawer)
161 {
162 result.m_debugDrawer->drawSphere(c,0.2f,btVector3(1,1,1));
163 }
165
167
168
169 //don't report time of impact for motion away from the contact normal (or causes minor penetration)
171 return false;
172
174
175
176
178
179 if (lambda > btScalar(1.))
180 return false;
181
182 if (lambda < btScalar(0.))
183 return false;
184
185
186 //todo: next check with relative epsilon
187 if (lambda <= lastLambda)
188 {
189 return false;
190 //n.setValue(0,0,0);
191 break;
192 }
194
195
196
197 //interpolate to next lambda
199
203
204 if (result.m_debugDrawer)
205 {
206 result.m_debugDrawer->drawSphere(interpolatedTransA.getOrigin(),0.2f,btVector3(1,0,0));
207 }
208
209 result.DebugDraw( lambda );
210
213
214 if (pointCollector.m_hasResult)
215 {
216 dist = pointCollector.m_distance+result.m_allowedPenetration;
217 c = pointCollector.m_pointInWorld;
218 n = pointCollector.m_normalOnBInWorld;
219 } else
220 {
221 result.reportFailure(-1, numIter);
222 return false;
223 }
224
225 numIter++;
226 if (numIter > maxIter)
227 {
228 result.reportFailure(-2, numIter);
229 return false;
230 }
231 }
232
233 result.m_fraction = lambda;
234 result.m_normal = n;
235 result.m_hitPoint = c;
236 return true;
237 }
238
239 return false;
240
241}
242
#define MAX_ITERATIONS
This maximum should not be necessary.
const T & btMax(const T &a, const T &b)
Definition btMinMax.h:29
btScalar length(const btQuaternion &q)
Return the length of a quaternion.
float btScalar
The btScalar type abstracts floating point numbers, to easily switch between double and single floati...
Definition btScalar.h:292
#define SIMD_EPSILON
Definition btScalar.h:521
#define btSimplexSolverInterface
int getShapeType() const
virtual btScalar getAngularMotionDisc() const
getAngularMotionDisc returns the maximum radius needed for Conservative Advancement to handle time-of...
btContinuousConvexCollision(const btConvexShape *shapeA, const btConvexShape *shapeB, btSimplexSolverInterface *simplexSolver, btConvexPenetrationDepthSolver *penetrationDepthSolver)
void computeClosestPoints(const btTransform &transA, const btTransform &transB, struct btPointCollector &pointCollector)
const btStaticPlaneShape * m_planeShape
btConvexPenetrationDepthSolver * m_penetrationDepthSolver
btSimplexSolverInterface * m_simplexSolver
virtual bool calcTimeOfImpact(const btTransform &fromA, const btTransform &toA, const btTransform &fromB, const btTransform &toB, CastResult &result)
cast a convex against another convex object
ConvexPenetrationDepthSolver provides an interface for penetration depth calculation.
The btConvexShape is an abstract shape interface, implemented by all convex shapes such as btBoxShape...
virtual btScalar getMargin() const =0
btGjkPairDetector uses GJK to implement the btDiscreteCollisionDetectorInterface
The btStaticPlaneShape simulates an infinite non-moving (static) collision plane.
static void integrateTransform(const btTransform &curTrans, const btVector3 &linvel, const btVector3 &angvel, btScalar timeStep, btTransform &predictedTransform)
static void calculateVelocity(const btTransform &transform0, const btTransform &transform1, btScalar timeStep, btVector3 &linVel, btVector3 &angVel)
The btTransform class supports rigid transforms with only translation and rotation and no scaling/she...
Definition btTransform.h:34
btTransform inverse() const
Return the inverse of this transform.
btVector3 can be used to represent 3D points and vectors.
Definition btVector3.h:84
btScalar dot(const btVector3 &v) const
Return the dot product.
Definition btVector3.h:235
void setValue(const btScalar &_x, const btScalar &_y, const btScalar &_z)
Definition btVector3.h:652
RayResult stores the closest result alternatively, add a callback method to decide about closest/all ...