Presentation is loading. Please wait.

Presentation is loading. Please wait.

CO Games Concepts Week 12 Collision Detection

Similar presentations


Presentation on theme: "CO Games Concepts Week 12 Collision Detection"— Presentation transcript:

1 CO1301 - Games Concepts Week 12 Collision Detection
Gareth Bellaby

2 Vectors Rabin, Introduction to Game Development:
4.2: "Collision Detection and Resolution" Van Verthe, Essential Mathematics for Games: 14.6: "A Simple Collision System"

3 Topics Vector practice Collision detection

4 Topic 1: Vector Practice

5 Right-angled triangles
With a right-angled triangle the length of the longest side is equal to the square root of the sum of the squares of the other two sides.

6 Vector between two points
The vector V from P1 to P2 is P1 subtracted from P2. The vector V from P1 to P2 is: = V( X2 - X1, Y2 - Y1, Z2 - Z1)

7 Length of a vector A vector makes a right-angled triangle.
Use Pythagoras’ Theorem about right-angle triangles. If we have a vector V(X, Y, Z) then:

8 Normalised vector A normal is any vector whose length is 1.
It is the direction vector. A vector is converted to a normal (normalised) by dividing the components by the length:

9 Topic 2: Collision Detection

10 Collision Detection Collision detection is a common operation. You often need to able to determine whether two things have collided: A bullet hitting a target A racing car reaching the winning point The player-character trying to move through a wall Checking whether an event has triggered, e.g. a triggered piece of dialogue or a monster jumping out. Distance calculations also come under this topic.

11 Point to Point The objects move frame by frame.
Calculate the distance between the two points.

12 Point to Point Example: a bullet striking a bull's eye.
Point to point is the simplest case. Point to point is simply a matter of working out the distance between two points. This is the same calculation as the length of a vector.

13 Bounding volumes Most objects in a game are not points so you cannot use point to point calculations. It is time consuming and mathematically complex to test whether two complex objects intersect. Instead use a simplified shape that fits around the object.

14 Bounding volumes Complex objects Bounding spheres

15 Bounding volumes Make the bounding volume as close a fit as possible.
Spheres and boxes are two commonly used shapes. Sacrificing precision for efficiency (speed). Bounding volumes are also used for a initial coarse check before engaging in more fine detailed analysis, e.g. a bounding sphere can be employed to see whether there is any chance of collision.

16 Point to Sphere Check to see whether a point has collided with a sphere. The radius of a sphere is the distance from the centre of the sphere to the edge of the sphere. Calculate the distance from the point to the centre of the sphere. If the distance is smaller than the radius of the sphere then a collision has occurred.

17 Point to Sphere

18 Sphere to Sphere Surround the object with a close fitting sphere.
The radius of a sphere is the distance from the centre of the sphere to its edge. Calculate the distance from the centre of the first sphere to the centre of the second sphere. If the distance is smaller than the sum of the sphere radiuses then a collision has occurred.

19 Sphere to Sphere

20 Bounding volumes Spheres are useful because the maths is comparatively simple - it's just an extension of vector calculations. Spheres also suit some objects, e.g. people (you would probably use a cylinder in practice, but 2 dimensionally a sphere is equivalent to a cylinder). However, spheres do not suit all objects, e.g. a crate or a house. In these cases a box would be more useful.

21 Bounding boxes The simplest box is an "axis-aligned" bounding box. The box is exactly aligned with the axes, e.g. horizontally and vertically.

22 Bounding boxes A box which is not axis-aligned will be more difficult to use. However, some objects fit better inside a box than a sphere. A problem arises if the object can rotate. Boxes better suit objects that cannot rotate. It is possible to do the calculations for a non-axis aligned bounding box. However, I am going to leave this until we move on to planes and point to plane collisions.

23 Point to Axis Aligned Box
Check the position of the point against the minimum and maximum x, y and z values of the box.

24 Sphere to Box The easiest way to implement this is to do a bit of sideways thinking. The sphere collides with the box when its edge crosses over the edge of the box. This can only happen if the distance from the centre of the sphere to the edge of the box is smaller than the radius of the sphere. So lets expand the size of the bounding box by the radius instead. Now do a simple point to box calculation instead.

25 Sphere to Box Note that this method is inaccurate at the corners
As point to box but add the radius to the maximum x, y and z values of the box, and subtract it from the minimum x, y and z values.

26 Collision Resolution The order of operation is: Collision Detection
Need to have a resolution because: An object moves over the course of one frame to the next If an object collides with an obstacle and we do not attempt to resolve the collision immediately... The object could become stuck because it may well be inside the obstacle.

27 Collision Resolution Moving frame-by-frame...
Therefore the object is inside the obstacle when the collision is detected... Hence it will become stuck inside the object.

28 Implementing Simple Collision Resolution
Move the model. Record the movement vector used to move the model (x, y, z). Check if a collision has occurred. If a collision has occurred: Move the model back to where it was at the beginning of the frame (-x, -y, -z) Note that this is simplistic. You should check to see where along the path of movement the collision occurred and set the position to this location. You will look at the maths to do at a later time.


Download ppt "CO Games Concepts Week 12 Collision Detection"

Similar presentations


Ads by Google