1.0 KiB
1.0 KiB
title | date | weight |
---|---|---|
GJK2D | 2019-09-15T11:19:13-07:00 | 20 |
GJK2D is a static class containing a single public method which is used for narrow-phase collision detection.
Methods
public static (bool, SimplexVertices) TestCollision(IShape2D shapeA, Transform2D transformA, IShape2D shapeB, Transform2D transformB)
Returns a tuple containing two values: the collision result and the simplex. If there is an overlap, the simplex will contain the termination simplex that can be used as a starting point for the Expanding Polytope Algorithm to compute a penetration vector. Otherwise, the simplex can be ignored.
Example:
var circleA = new Circle(2);
var transformA = new Transform2D(new Vector2(-1, -1));
var circleB = new Circle(2);
var transformB = new Transform2D(new Vector2(1, 1));
var (result, simplex) = GJK2D.TestCollision(circleA, transformA, circleB, transformB);
In this example, these transformed circles are indeed overlapping, so result will be true and simplex will contain the termination simplex.