|
Bullet Collision Detection & Physics Library
|
#include "LinearMath/btTransform.h"#include "btGjkEpa3.h"#include "btGjkCollisionDescription.h"#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h"
Go to the source code of this file.
Functions | |
| template<typename btConvexTemplate > | |
| bool | btGjkEpaCalcPenDepth (const btConvexTemplate &a, const btConvexTemplate &b, const btGjkCollisionDescription &colDesc, btVector3 &v, btVector3 &wWitnessOnA, btVector3 &wWitnessOnB) |
| template<typename btConvexTemplate , typename btGjkDistanceTemplate > | |
| int | btComputeGjkEpaPenetration (const btConvexTemplate &a, const btConvexTemplate &b, const btGjkCollisionDescription &colDesc, btVoronoiSimplexSolver &simplexSolver, btGjkDistanceTemplate *distInfo) |
| int btComputeGjkEpaPenetration | ( | const btConvexTemplate & | a, |
| const btConvexTemplate & | b, | ||
| const btGjkCollisionDescription & | colDesc, | ||
| btVoronoiSimplexSolver & | simplexSolver, | ||
| btGjkDistanceTemplate * | distInfo | ||
| ) |
this is another degenerate case, where the initial GJK calculation reports a degenerate case EPA reports no penetration, and the second GJK (using the supporting vector without margin) reports a valid positive distance. Use the results of the second GJK instead of failing. thanks to Jacob.Langford for the reproduction case http://code.google.com/p/bullet/issues/detail?id=250
Definition at line 61 of file btComputeGjkEpaPenetration.h.
| bool btGjkEpaCalcPenDepth | ( | const btConvexTemplate & | a, |
| const btConvexTemplate & | b, | ||
| const btGjkCollisionDescription & | colDesc, | ||
| btVector3 & | v, | ||
| btVector3 & | wWitnessOnA, | ||
| btVector3 & | wWitnessOnB | ||
| ) |
Definition at line 25 of file btComputeGjkEpaPenetration.h.
1.8.16