Hi I'm making a voxel game in Java and while researching all the different things I'd need to learn, I noticed that a lot of games use AABB for collision detection. And then I remembered seeing AABB in Minecraft also. But when I google what AABB is, it only comes up with other peoples code, or some organization out the history book. Stackoverflow, what is AABB?
相关问题
- Enemy not staying at original spot
- When projectile hits two “monsters” the didBeginCo
- Javascript Collision Detection between circle and
- Simple drag physics, acting differently when movin
- Collision detection for an arc of a circle
相关文章
- About Collision detection alghorithms in AS3
- Tile map Collision Detection
- C# simple 3D Collision detection
- detect collision of two moving buttons in iPhone
- android 2d arc collision detection
- XNA - Pong Clone - Reflecting ball when it hits a
- Getting the Protrusion and Collision Data From Jqu
- LibGDX - properly using Polygon class
Axis Aligned Bounding Box
Basically its the smallest Cuboid that can completely contain the shape, usually defined by a pair of 3d co-ordinates.
It's very fast to check for collisions between two AABB as all you need to do is check the range of the X, Y and Z values for the corners.
AABB stands for "Axis-Aligned Bounding Box."
It is a fairly computationally- and memory-efficient way of representing a volume, typically used to see if two objects might be touching.
Since it is axis-aligned, it does not necessarily "fit" your real 3D object very well. AABB checks are often used as a coarse first-approximation to see if objects might be colliding. Then, if the AABB check passes, more detailed checks are made.
Example:
Imagine your world is 2D, and you draw it on a sheet of graph paper. You have some objects in the world (a ball, a tree, whatever). To make an AABB for one of the objects, you draw a rectangle around the object, making your lines parallel to the grid lines on the paper.
If you have the AABB for two objects, you can do some pretty simple math to see if those AABBs overlap. If they don't overlap, those two objects couldn't possibly be touching, so it's an easy early-out for your collision algorithm.
This generalizes to 3D (and more-Ds) fairly easily.
You might want to check out gamedev.stackexchange.com, too.