Introduction to collision
Unity handles collision between GameObjects with colliders, which attach to GameObjects and define the shape of a GameObject The fundamental object in Unity scenes, which can represent characters, props, scenery, cameras, waypoints, and more. A GameObject’s functionality is defined by the Components attached to it. More info
See in Glossary for the purposes of physical collisions. A collider is invisible, and does not need to be the exact same shape as the GameObject’s mesh The main graphics primitive of Unity. Meshes make up a large part of your 3D worlds. Unity supports triangulated or Quadrangulated polygon meshes. Nurbs, Nurms, Subdiv surfaces must be converted to polygons. More info
See in Glossary . A rough approximation of the mesh is often more efficient and indistinguishable in gameplay.
The simplest (and least processor-intensive) colliders are primitive collider types. In 3D, these are the Box Collider A cube-shaped collider component that handles collisions for GameObjects like dice and ice cubes. More info
See in Glossary , Sphere Collider A sphere-shaped collider component that handles collisions for GameObjects like balls or other things that can be roughly approximated as a sphere for the purposes of physics. More info
See in Glossary and Capsule Collider A capsule-shaped collider component that handles collisions for GameObjects like barrels and character limbs. More info
See in Glossary . In 2D, you can use the Box Collider 2D and Circle Collider 2D. You can add any number of these to a single GameObject to create compound colliders.
Compound colliders
Compound colliders approximate the shape of a GameObject while keeping a low processor overhead. To get further flexibility, you can add additional colliders on child GameObjects. For instance, you can rotate boxes relative to the local axes of the parent GameObject. When you create a compound collider like this, you should only use one Rigidbody A component that allows a GameObject to be affected by simulated gravity and other forces. More info
See in Glossary component, placed on the root GameObject in the hierarchy.
Primitive colliders do not work correctly with shear transforms. If you use a combination of rotations and non-uniform scales in the Transform hierarchy so that the resulting shape is no longer a primitive shape, the primitive collider cannot represent it correctly.
Mesh colliders
There are some cases, however, where even compound colliders are not accurate enough. In 3D, you can use Mesh Colliders A free-form collider component which accepts a mesh reference to define its collision surface shape. More info
See in Glossary to match the shape of the GameObject’s mesh exactly. In 2D, the Polygon Collider 2D does not match the shape of the sprite A 2D graphic objects. If you are used to working in 3D, Sprites are essentially just standard textures but there are special techniques for combining and managing sprite textures for efficiency and convenience during development. More info
See in Glossary graphic perfectly but you can refine the shape to any level of detail The Level Of Detail (LOD) technique is an optimization that reduces the number of triangles that Unity has to render for a GameObject when its distance from the Camera increases. More info
See in Glossary you like.
These colliders are much more processor-intensive than primitive types, so use them sparingly to maintain good performance. Also, a mesh collider cannot collide with another mesh collider (i.e., nothing happens when they make contact). You can get around this in some cases by marking the mesh collider as Convex in the Inspector A Unity window that displays information about the currently selected GameObject, asset or project settings, allowing you to inspect and edit the values. More info
See in Glossary . This generates the collider shape as a “convex hull” which is like the original mesh but with any undercuts filled in.
The benefit of this is that a convex mesh collider can collide with other mesh colliders so you can use this feature when you have a moving character with a suitable shape. However, a good rule is to use mesh colliders for scene A Scene contains the environments and menus of your game. Think of each unique Scene file as a unique level. In each Scene, you place your environments, obstacles, and decorations, essentially designing and building your game in pieces. More info
See in Glossary geometry and approximate the shape of moving GameObjects using compound primitive colliders.
Static colliders
You can add colliders to a GameObject without a Rigidbody component to create floors, walls and other motionless elements of a Scene. These are referred to as static colliders. At the opposite, colliders on a GameObject that has a Rigidbody are known as dynamic colliders. Static colliders can interact with dynamic colliders but since they don’t have a Rigidbody, they don’t move in response to collisions.
Physics materials
When colliders interact, their surfaces need to simulate the properties of the material they are supposed to represent. For example, a sheet of ice will be slippery while a rubber ball will offer a lot of friction and be very bouncy. Although the shape of colliders is not deformed during collisions, their friction and bounce can be configured using Physics Materials. Getting the parameters just right can involve a bit of trial and error. A slippery material like ice, for example, has zero (or very low) friction. A grippy material like rubber has high friction and near-perfect bounciness. See the reference pages for Physic Material and Physics Material 2D for further details on the available parameters. Note that for historical reasons, the 3D asset is actually called Physic Material A physics asset for adjusting the friction and bouncing effects of colliding objects. More info
See in Glossary (without the S) but the 2D equivalent is called Physics Material 2D Use to adjust the friction and bounce that occurs between 2D physics objects when they collide More info
See in Glossary (with the S).
Triggers
The scripting system can detect when collisions occur and initiate actions using the OnCollisionEnter function. However, you can also use the physics engine A system that simulates aspects of physical systems so that objects can accelerate correctly and be affected by collisions, gravity and other forces. More info
See in Glossary simply to detect when one collider enters the space of another without creating a collision. A collider configured as a Trigger (using the Is Trigger property) does not behave as a solid object and will simply allow other colliders to pass through. When a collider enters its space, a trigger will call the OnTriggerEnter function on the trigger object’s scripts A piece of code that allows you to create your own Components, trigger game events, modify Component properties over time and respond to user input in any way you like. More info
See in Glossary .
Collision callbacks for scripts
When collisions occur, the physics engine calls functions with specific names on any scripts attached to the objects involved. You can place any code you like in these functions to respond to the collision event. For example, you might play a crash sound effect when a car bumps into an obstacle.
On the first physics update where the collision is detected, the OnCollisionEnter function is called. During updates where contact is maintained, OnCollisionStay is called and finally, OnCollisionExit indicates that contact has been broken. Trigger colliders call the analogous OnTriggerEnter , OnTriggerStay and OnTriggerExit functions. Note that for 2D physics, there are equivalent functions with 2D appended to the name, eg, OnCollisionEnter2D . Full details of these functions and code samples can be found on the Script Reference page for the MonoBehaviour class.
With normal, non-trigger collisions, there is an additional detail that at least one of the objects involved must have a non-kinematic Rigidbody (ie, Is Kinematic must be switched off). If both objects are kinematic Rigidbodies then OnCollisionEnter , etc, will not be called. With trigger collisions, this restriction doesn’t apply and so both kinematic and non-kinematic Rigidbodies will prompt a call to OnTriggerEnter when they enter a trigger collider.
Collider interactions
Colliders interact with each other differently depending on how their Rigidbody components are configured. The three important configurations are the Static Collider (ie, no Rigidbody is attached at all), the Rigidbody Collider and the Kinematic Rigidbody Collider.
Static Collider
A static collider is a GameObject that has a Collider but no Rigidbody. Static colliders are mostly used for level geometry which always stays at the same place and never moves around. Incoming Rigidbody objects collide with static colliders but don’t move them.
In particular cases, the physics engine optimizes for static colliders that never move. For instance, a vehicle resting on top of a static collider remains asleep even if you move this static collider. You can enable, disable, or move static colliders in runtime without specially affecting the physics engine computation speed. Also, you can safely scale a static Mesh Collider as long as the scale is uniform (not skewed).
Rigidbody Collider
This is a GameObject with a Collider and a normal, non-kinematic Rigidbody attached. Rigidbody colliders are fully simulated by the physics engine and can react to collisions and forces applied from a script. They can collide with other objects (including static colliders) and are the most commonly used Collider configuration in games that use physics.
Kinematic Rigidbody Collider
This is a GameObject with a Collider and a kinematic Rigidbody attached (ie, the IsKinematic property of the Rigidbody is enabled). You can move a kinematic rigidbody object from a script by modifying its Transform Component A Transform component determines the Position, Rotation, and Scale of each object in the scene. Every GameObject has a Transform. More info
See in Glossary but it will not respond to collisions and forces like a non-kinematic rigidbody. Kinematic rigidbodies should be used for colliders that can be moved or disabled/enabled occasionally but that should otherwise behave like static colliders. An example of this is a sliding door that should normally act as an immovable physical obstacle but can be opened when necessary. Unlike a static collider, a moving kinematic rigidbody will apply friction to other objects and will “wake up” other rigidbodies when they make contact.
Even when immobile, kinematic rigidbody colliders have different behavior to static colliders. For example, if the collider is set to as a trigger then you also need to add a rigidbody to it in order to receive trigger events in your script. If you don’t want the trigger to fall under gravity or otherwise be affected by physics then you can set the IsKinematic property on its rigidbody.
A Rigidbody component can be switched between normal and kinematic behavior at any time using the IsKinematic property.
A common example of this is the “ragdoll” effect where a character normally moves under animation but is thrown physically by an explosion or a heavy collision. The character’s limbs can each be given their own Rigidbody component with IsKinematic enabled by default. The limbs move normally by animation until IsKinematic is switched off for all of them and they immediately behave as physics objects. At this point, a collision or explosion force will send the character flying with its limbs thrown in a convincing way.
Collision action matrix
When two objects collide, a number of different script events can occur depending on the configurations of the colliding objects’ rigidbodies. The charts below give details of which event functions are called based on the components that are attached to the objects. Some of the combinations only cause one of the two objects to be affected by the collision, but the general rule is that physics will not be applied to an object that doesn’t have a Rigidbody component attached.
Detect collision in Unity 3D
In this tutorial, we will see how to detect collision in unity 3D between different game objects. We will use Collision class to detect the collisions between game objects.
We will use below scene for demo.
Demo Scene
We will move player object with keyboard input and check it’s collision with other objects.
Steps to detect collision in Unity 3D
Step 1:
The game object on which collision detection will be triggered should be having Rigid Body and Collider components. For this demo, we will attach Rigid body component to the player game object. Box collider is already available to primitive Cube objects.
Player Object
Make sure Is Kinematic check box is unchecked.
Step 2:
Attach Collider components to the other game objects. Here we have added Box Collider to Ground and Enemy Game Objects. Rigid Body component is optional. Make sure that “Is Trigger” checkbox is unchecked.
Enemy Object
Unity collision detection 2D everything you need to know + examples
Here we are, I can feel another mystery, Unity collision detection 2D.
What? It’s too difficult this time!?
I don’t think so.
It’s a big case, I know, but if we want to create video games we need to face the truth:
Manage collisions.
Don’t worry we will find all the necessary information and this time we will have another partner to help for our investigation: Unity.
Yes, Unity will help us, then we just need to start analyzing the clues.
Step by step we will understand how to manage the collisions in our game and this monstrous case will become a lovely little kitten.
Unity Collisions Vocabulary
Hey partner, here is what I already discovered, there are some important notions to know before proceeding and understanding Unity collision detection 2D:
Physics Engine 2D
To detect collisions and simulate the real world physics system Unity provides a built-in physics engine, so all the maths behind acceleration, forces, gravity, collision detection etc… it’s already there.
Fewww! It seems other brave detectives already solved the case of physics! Thank you whoever you are!
Collision Detection
It’s the detection of an intersection between two or multiple objects. Often it’s related to simulate the physical world in our game.
Let me list for you some detections we would like to handle:
- One object (or multiple objects) touches or hits another object (or multiple objects)
- One object (or multiple objects) overlaps another object (or multiple objects)
The detection means that in some way we need to be warned when a collision happens!
Please have a look at wikipedia for a large definition about collision detections in video games.
Collider 2D
It’s a component to define the shape of a Gameobject for physical purposes.
If the Gameobject sprite is a complex drawing, just an approximation of its shape will be necessary to work, because the Collider 2D is invisible and not distinguishable during the gameplay!
So the sprite is the drawing, the collider is the shape, what does it mean?
The sprite is what the user sees, the collider is what the engine considers for collisions.
Trigger 2D
It’s a particular behavior of a Collider 2D, when we simply want to detect when one collider overlaps another one without creating a collision.
So the object with this behavior stops being a solid object and allows other colliders to pass through.
RigidBody 2D
It’s a component that allows the physics engine to control the object, it means it will be affected by gravity, forces and collisions too!
Are you ready to play with Vectors?
Right, to move our objects in different directions we need to manage vectors too! Why don’t you have a look at this article for a good refresh: Vector In Game Development: Understand The Basics Of Vector Math
While the physics engine 2D moves colliders and makes them interact with each other, the Rigidbody 2D component is in charge of the communication of these movements with the Transform components.
In this way the Gameobject will change according to the collider!
How to…
How can we add a Collider 2D or Rigidbody 2D to a Gameobject?
1- Select a Gameobject in the scene and click on add component.
2- Type “collider 2D” or “rigidbody 2D” in the search box and select the component (for Collider 2D we will see different types, we’re just going to talk about it).
How can we set a collider as a trigger?
Just enabling the right checkbox property in the Collider 2D component.
Which Collider 2D should we use?
Have you noticed there is more than one Collider 2D to choose from?
Yes, Unity provides us a list of different already pre-set Collider 2Ds.
Unity has an explanation for each one, we just need to enrich it with some helpful examples.
Let’s line up all the suspects then and have a look at each one of them (On the left is the sprite, on the right its collider)
Box Collider 2D
Box collider 2D is for square and rectangle collision areas.
Circle Collider 2D
Circle collider 2D is for circular collision areas.
Capsule Collider 2D
Capsule collider 2D is for circular or lozenge-shaped collision areas.
Polygon Collider 2D
Polygon collider 2D is for freeform collision areas.
Edge Collider 2D
Edge collider 2D is for freeform collision areas and areas which aren’t completely enclosed (such as rounded convex corners).
Composite Collider 2D
Composite collider 2D is for merging Box Collider 2Ds and Polygon Collider 2Ds.
Tilemap Collider 2D
Tilemap Collider 2D is for each Tile set in the corresponding Tilemap component of a Tilemap Gameobject. We’ll talk about it in the Tilemap investigation!
Rigidbody 2D Types
More than one Rigidbody 2D type? Are you sure? I knew it! Some witnesses saw something!
Let’s try to find out the version of the story of each Rigidbody 2D.
Dynamic Rigidbody 2D
It’s the most common and most performance-expensive type, because it interacts with everything and it’s designed to move under simulation. It interacts with all the body types.
If we want a normal object affected by physics, this is our body!
The ball in this example has a dynamic Rigidbody 2D and it can be moved by applying forces and it’s affected by gravity!
Static Rigidbody 2D
Opposite to dynamic, it’s designed to not move under simulation, Indeed it has infinite mass, heavy right? It only collides with dynamic Rigidbody 2D.
It is also the least resource-intensive body type to use.
You don’t really need to set the Rigidbody 2D for static objects, just the collider 2D is necessary to detect collisions, but if a static object needs to be moved or reconfigured at run time, it is faster to do so when it has its own Rigidbody 2D and this will be our body!
Let’s add a box with static Rigidbody2D, it will be an obstacle to overcome!
Kinematic Rigidbody 2D
Like the dynamic is designed to move under simulation, but only controlling it, it’s not affected by gravity and forces. It’s faster in terms of performance-expensive. It interacts only with dynamic body types.
If we want to move something not influenced by forces and gravity, remember it’s nature of interaction only with dynamic body types, this is our body!
What if we add a kinematic Rigidbody 2D instead of the static one to the box? In this way we can control its movement without the influence of gravity. It will become a perfect movement trap for a platform video game!
Collision Detection 2D in scripts
Well! Now we know many things about Unity collision detection 2D, we are ready to understand what we can do when a collision happens.
Unity, our partner provides us two different ways to handle the collisions depending if a collider is a trigger or not.
We just need to add the snippets below to the script of our Gameobject with a collider to handle the collisions and do what we want after the detection.
Just keep in mind if the trigger checkbox is unchecked we need the “Collision 2D” snippets, otherwise if not “Trigger 2D” .
Collision 2D
Trigger 2D
Keep in mind… Mind the gap!
Hey partner! Unity collision detection 2D is not a secret anymore for us, but we can’t solve this case without considering these clues:
Colliders 2D Properties
Each collider type has properties over the trigger one, please check the documentation for each type to understand what these properties do (in the section “Which Collider 2D should we use” you can find a link for each collider type to its documentation).
Rigidbody 2D properties
There are some properties like mass and gravity we will need to know, I suggest having a look at the official documentation for an explanation of all of them.
Static collider 2D
It was “static Rigidbody 2D” wasn’t it? You’re right, but if we need just the collision detection without any reconfiguration or movement to place the object somewhere else, we can avoid adding the Rigidbody 2D component.
Put something below or set the gravity value to 0 to avoid falling objects.
It’s a common mistake, when we add a dynamic or static Rigidbody 2D to an object, if we start the game the object will fall out of the screen. To avoid this we can either place a floor underneath with a collider, or set the gravity value attribute in the rigidbody component to 0.
2D is NOT 3D
As you already noticed Unity provides many of these components in 2 versions, for instance Box Collider 2D and Box Collider, well the difference is the second one is for 3D. So keep in mind to use only 2D components in 2D games, first for performances and second to avoid mixing things that won’t work like 3D components and 2D methods in scripts (OnCollisionEnter2D is NOT OnCollisionEnter).
OnCollisionEnter2D won’t work if the trigger is enabled and vice versa.
Remember my friend, for collisions “OnCollisionEnter2D, OnCollisionStay2D, OnCollisionExit2D”, but if we enable the trigger behaviour in a collider they will stop working and we should use “OnTriggerEnter2D, OnTriggerStay2D, OnTriggerExit2D”.
Simple collisions 2D game
Hey! Look what I found in the secret files of the blog, An old record! Someone already tried to solve this case.
Here is my reconstruction of the record:
Whoever will be able to reproduce it will help to solve the lost case of collision 2D game.
Besides this they will win the best detective of the month prize!
Do you think you will be able to figure it out?
If not, don’t worry, you can find the complete project on GitHub, but promise me to look at it only as the last resort!
Conclusion
It was a hard job, we needed a lot of research, so let’s do a final recap:
- To detect collisions in a Gameobject we need a Collider2D, with the right type according to our needs.
- To allow physics 2D to affect a Gameobject we need a RigidBody2D.
- Keep in mind all the rules we discussed before configuring the game properly and you will avoid unwanted behaviors.
No collision fear anymore, we solved the case and acquired the knowledge required to create a wonderful video game with collision detection.
Урок 1 — Основы обнаружения столкновений.
В уроке рассказывается как обнаружить столкновения (collisions) между объектами используя скрипты.
Создайте сцену как в предыдущем уроке или загрузите уже имеющуюся. Добавьте к ней еще один куб, растяните его по горизонтали в 5-6ть раз и по вертикали в 2а раза. Расположите его как показано на рисунке ниже.
В этом уроке важны названия объектов. Назовите плоскость Floor, а куб представляющий стену Wall (Ваш К.О.)
В Project View нажмите на Create и выберете С# Script. Назовите его boxdrop. Дважды кликнув на скрипт вы откроете его в вашем редакторе скриптов (как правило, по умолчанию это MonoDevelop. У автора статьи это Visual Studio 2010 под Windows или Textmate под MacOs).
Обратите внимание, что название класса всегда должно совпадать с названием скрипта(регистр букв тоже имеет значение):
//Важно! Названия основного класса всегда должно совпадать с названием файла скрипта
public class boxdrop : MonoBehaviour <
По умолчанию Unity создает каркас для C# скрипта. Удалите из тела класса boxdrop все содержимое и замените следующим:
// Метод вызываемый при столкновении объекта
Debug.Log(“Hit Something”); // Передаем сообщение в консоль Unity
Функция OnCollisionEnter определяет столкновение объекта с другими объектами. А статический метод Log класса Debug пишет сообщение в консоль Unity. После сохранения скрипта, добавьте его как компонент для падающего куба.
Теперь если вы нажмете Play, в момент когда куб коснется пола консоль выдаст соответствующее сообщение. Открыть окно консоли можно комбинацией ctrl + shift + c в Windows или cmd + shift + c в MacOs. Последнее консольное сообщение отображается в статус баре проекта (внизу окна).
Причем сообщение будет выдаваться при каждом столкновении.
Для того, чтобы понять с каким именно объектом столкнулся наш куб, мы будем брать значение параметра класса Collision, которое будет принимать метод OnCollisionEnter:
// Теперь метод принимает объект класса Collision, с которым происходит столкновение
void OnCollisionEnter(Collision myCollision) <
// определение столкновения с двумя разноименными объектами
if (myCollision.gameObject.name == “Floor”) <
// Обращаемся к имени объекта с которым столкнулись
else if (myCollision.gameObject.name == “Wall”) <
Нажмите Play и после того как ваш куб коснется несколько раз стены и пола остановите игру и откройте консоль. Теперь при столкновении только со стеной или полом будет выдаваться соответствующие названию объекта сообщение.