data:image/s3,"s3://crabby-images/9b345/9b34545d6a0c36c8da767a0bc5fe26cff27f08c4" alt=""
Level: Very Beginner
What is AABB?
AABB stands for Axis-Aligned Bounding Box, it is an algorithm to detect collision between a rectangle’s edges, in this case, those edges are parallel with coordinate axes. Basically, we will check two rectangles overlap with each other or not.
What is Swept AABB?
We will have some problems if we use AABB, let’s see this example:
data:image/s3,"s3://crabby-images/b30b4/b30b4af901bec00469988eb1f2dc8ede9f653392" alt=""
In the first frame, rectangle 1 doesn’t collide with a blue rectangle. And next frame, the rectangle 1 move to the next position, but velocity too fast and make it go through the blue rectangle. If we check collision at this frame, rectangle 1 doesn’t collide with the blue one.
Let’s think if we can predict the next position in the next frame, we will know and prevent our object from this problem. This is called Swept AABB.
AABB Collision
To check 2 rectangles are overlapped each other or not, we will check each pair of corresponding edges.
data:image/s3,"s3://crabby-images/f5641/f56413dcbc803968895965b28cbe34d13810b2e6" alt=""
We always have this at the same time:
other.left <= object.right
other.right >= object.left
other.top >= object.bottom
other.bottom <= object.top
If one of these conditions is wrong, so 2 rectangles aren’t overlapped.
data:image/s3,"s3://crabby-images/75396/7539650cb92cd093ea9d9b9136cb1b3f924ce4c0" alt=""
In this example, we have ‘left’ of ‘other’ greater than ‘right’ of ‘object’.
Noted: all examples in this article use bottom-left origin.
This is a simple function to check collision:
data:image/s3,"s3://crabby-images/d7fac/d7fac2405433585bd671576bb132b5ae661a166b" alt=""
We can invert conditions to check faster.
Using Swept
First, we calculate the distance between the corresponding edges.
data:image/s3,"s3://crabby-images/80c03/80c03242ab05de5715f11f72c5ed54bc1df488d4" alt=""
In this,
dxEntry, dyEntry: the distance need to move to begin contact
dxExit, dyExit: the distance need to move to exit contact
We also need to check the sign of velocity and calculate the distance in each case
data:image/s3,"s3://crabby-images/8207f/8207fc90732dd67f199f03c994da067d0f481b1a" alt=""
Next, from distance and velocity, we can calculate the time
|| time = distance / velocity
data:image/s3,"s3://crabby-images/eae45/eae45031480a47e7cd2f3bb3650eb15918034e4e" alt=""
In order to collide, both axes x and y need to get collided. So, we will take the longest time to begin collision.
And when end collision, we only need one of the axes exit collision, so we will take the quickest time to exit collision.
data:image/s3,"s3://crabby-images/4f0e2/4f0e20a3c22ce34f2267cc082e69c651e9cc2815" alt=""
data:image/s3,"s3://crabby-images/f80b5/f80b56e3c9b196de257e60e3ded3b999b2f7a846" alt=""
We can check collision by:
time to begin collision from 0 to 1
time to end collision must be bigger than time to begin collision.
Finally, we will return time to begin a collision.
Handle collision
We can use it to calculate the distance need to move to the next frame based on the returned time.
data:image/s3,"s3://crabby-images/9cf86/9cf86ccae7c3e3d995befea481a873925b3a9c08" alt=""
Broad-Phasing
To optimize, we can do one more step by using a rectangle made from the position at the current frame and the next frame to check collision with another object.
data:image/s3,"s3://crabby-images/66bea/66bea5ad5cdbd2634aae8a6d220ac99e42aec8c6" alt=""
data:image/s3,"s3://crabby-images/8d236/8d2365fff4accc96c58b6e5257df0700547157c2" alt=""
We put this code at the top of Swept AABB function.
data:image/s3,"s3://crabby-images/094f3/094f3fd1836e7ee0f3d87e4a89882ae66166213a" alt=""
Detect collision direction
data:image/s3,"s3://crabby-images/72d4f/72d4fdc3d4846e31c9e8403f1b8285eb092e03d4" alt=""
That’s it! This algorithm is very simple, right?
I hope this basic concept can help you in your project and move to the more difficult algorithms like SAT (Separating Axis Theorem).
Kaiser OTC benefits provide members with discounts on over-the-counter medications, vitamins, and health essentials, promoting better health management and cost-effective wellness solutions.
Obituaries near me help you find recent death notices, providing information about funeral services, memorials, and tributes for loved ones in your area.
is traveluro legit? Many users have had mixed experiences with the platform, so it's important to read reviews and verify deals before booking.
Adultscare offers a variety of chastity cage for men, including metal and silicone options. These cages provide control and restraint for BDSM play. Designed for comfort and security, they come with adjustable locks for long-term wear. Check Adultscare for discreet delivery.
I came away from this post feeling much more knowledgeable! The author did a fantastic job explaining the topic. myunisastatus.co.za
The Swept AABB algorithm explains, which enhances collision detection by predicting objects along with the same thing as in the game among us where strategic planning and movement awareness can lead to success along with a game-winning strategy.