Bird
Raised Fist0
Unityframework~10 mins

Collider2D types (box, circle, polygon) in Unity - Step-by-Step Execution

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Concept Flow - Collider2D types (box, circle, polygon)
Start: Choose Collider2D Type
Box
Set Size
Apply Collider to GameObject
Physics Interaction
End
Choose a Collider2D type, set its shape parameters, apply it to a GameObject, then it interacts with physics.
Execution Sample
Unity
var box = gameObject.AddComponent<BoxCollider2D>();
box.size = new Vector2(2, 3);

var circle = gameObject.AddComponent<CircleCollider2D>();
circle.radius = 1.5f;

var polygon = gameObject.AddComponent<PolygonCollider2D>();
polygon.points = new Vector2[] { new Vector2(0,0), new Vector2(1,0), new Vector2(0,1) };
This code adds three different Collider2D types to a GameObject and sets their shape sizes.
Execution Table
StepActionCollider TypeProperty SetValueResult
1Add BoxCollider2DBoxsizedefault (1,1)Box collider added with default size
2Set Box sizeBoxsize(2,3)Box collider size updated to (2,3)
3Add CircleCollider2DCircleradiusdefault 0.5Circle collider added with default radius
4Set Circle radiusCircleradius1.5Circle collider radius updated to 1.5
5Add PolygonCollider2DPolygonpointsdefault []Polygon collider added with default points
6Set Polygon pointsPolygonpoints[(0,0),(1,0),(0,1)]Polygon collider points updated
7Physics InteractionAllN/AN/AColliders interact with physics engine
8ExitN/AN/AN/ASetup complete, colliders ready
💡 All colliders added and configured, physics engine uses them for collision detection
Variable Tracker
VariableStartAfter Step 1After Step 2After Step 3After Step 4After Step 5After Step 6Final
box.sizeN/A(1,1)(2,3)(2,3)(2,3)(2,3)(2,3)(2,3)
circle.radiusN/AN/AN/A0.51.51.51.51.5
polygon.pointsN/AN/AN/AN/AN/A[][(0,0),(1,0),(0,1)][(0,0),(1,0),(0,1)]
Key Moments - 3 Insights
Why do we need to set size or radius after adding a collider?
By default, colliders have preset sizes (like 1x1 for box or 0.5 radius for circle). Setting size or radius changes the shape to fit your object, as shown in steps 2 and 4 of the execution_table.
Can a GameObject have multiple Collider2D types at once?
Yes, as shown in steps 1, 3, and 5, you can add multiple colliders to the same GameObject to combine shapes for complex collision areas.
What does setting polygon points do?
It defines the exact shape of the polygon collider by specifying its vertices, as seen in step 6 where points are set to form a triangle.
Visual Quiz - 3 Questions
Test your understanding
Look at the execution_table at step 4. What is the circle collider's radius after this step?
A1.5
B0.5
C2
DNot set yet
💡 Hint
Check the 'Value' column at step 4 in the execution_table.
At which step does the polygon collider get its points updated to a triangle shape?
AStep 5
BStep 3
CStep 6
DStep 2
💡 Hint
Look for 'Set Polygon points' action in the execution_table.
If you skip setting the box collider size after adding it, what size will it have?
ASize (2,3)
BDefault size (1,1)
CZero size
DNo collider created
💡 Hint
Refer to step 1 and 2 in the execution_table to see default and updated sizes.
Concept Snapshot
Collider2D types in Unity:
- BoxCollider2D: rectangle shape, set size with 'size'
- CircleCollider2D: round shape, set radius with 'radius'
- PolygonCollider2D: custom shape, set points array
Add collider to GameObject, then adjust shape properties
Used for 2D physics collision detection
Full Transcript
This visual execution shows how to add and configure three types of Collider2D components in Unity: BoxCollider2D, CircleCollider2D, and PolygonCollider2D. First, each collider is added to a GameObject with default shape sizes. Then, their shape properties are set: size for box, radius for circle, and points for polygon. The variable tracker shows how these properties change step-by-step. Key moments clarify why setting these properties is important and that multiple colliders can coexist on one object. The quiz tests understanding of property values at specific steps. This helps beginners see exactly how colliders are created and customized for 2D physics.

Practice

(1/5)
1. Which Collider2D type is best suited for a rectangular game object in Unity?
easy
A. BoxCollider2D
B. CircleCollider2D
C. PolygonCollider2D
D. EdgeCollider2D

Solution

  1. Step 1: Understand the shape of the object

    A rectangle or square has straight edges and right angles.
  2. Step 2: Match the collider type to the shape

    BoxCollider2D fits rectangles and squares perfectly because it creates a box-shaped collision area.
  3. Final Answer:

    BoxCollider2D -> Option A
  4. Quick Check:

    Rectangle shape = BoxCollider2D [OK]
Hint: Rectangles use BoxCollider2D for perfect fit [OK]
Common Mistakes:
  • Choosing CircleCollider2D for rectangles
  • Using PolygonCollider2D unnecessarily for simple shapes
  • Confusing EdgeCollider2D with BoxCollider2D
2. Which of the following is the correct way to add a CircleCollider2D component to a GameObject in C# script?
easy
A. gameObject.AddComponent<BoxCollider2D>();
B. gameObject.AddComponent<PolygonCollider2D>();
C. gameObject.AddComponent<CircleCollider2D>();
D. gameObject.AddComponent<EdgeCollider2D>();

Solution

  1. Step 1: Identify the correct component type

    CircleCollider2D is the component for circular collision shapes.
  2. Step 2: Use AddComponent with the correct type

    The syntax is gameObject.AddComponent<Type>(); so for circle, use CircleCollider2D.
  3. Final Answer:

    gameObject.AddComponent<CircleCollider2D>(); -> Option C
  4. Quick Check:

    Add CircleCollider2D with AddComponent<> [OK]
Hint: Use AddComponent<CircleCollider2D>() for circle colliders [OK]
Common Mistakes:
  • Using wrong collider type in AddComponent
  • Missing angle brackets <> in AddComponent
  • Confusing BoxCollider2D with CircleCollider2D
3. What will happen if you assign a PolygonCollider2D to a GameObject and set its points to form a triangle shape?
medium
A. The GameObject will have a circular collision area ignoring the points.
B. The GameObject will have a triangular collision area matching the points.
C. The GameObject will throw a runtime error due to invalid points.
D. The GameObject will have a box-shaped collision area by default.

Solution

  1. Step 1: Understand PolygonCollider2D behavior

    PolygonCollider2D uses points to define a custom shape for collision.
  2. Step 2: Setting points to triangle shape

    When points form a triangle, the collider matches that triangle shape exactly.
  3. Final Answer:

    Triangular collision area matching points -> Option B
  4. Quick Check:

    PolygonCollider2D shape = points defined [OK]
Hint: PolygonCollider2D matches shape from points given [OK]
Common Mistakes:
  • Assuming PolygonCollider2D defaults to box or circle
  • Expecting errors from valid point sets
  • Confusing PolygonCollider2D with BoxCollider2D
4. You wrote this code to add a BoxCollider2D but it doesn't appear on your GameObject:
var collider = gameObject.AddComponent<BoxCollider2D>;
collider.size = new Vector2(2, 3);
What is the error?
medium
A. AddComponent cannot be used in scripts
B. BoxCollider2D does not have a size property
C. Vector2 should be Vector3 for size
D. Missing parentheses after AddComponent<BoxCollider2D>

Solution

  1. Step 1: Check AddComponent syntax

    AddComponent is a method and requires parentheses: AddComponent<Type>()
  2. Step 2: Identify the missing parentheses

    The code uses AddComponent<BoxCollider2D> without () which causes no component to be added.
  3. Final Answer:

    Missing parentheses after AddComponent<BoxCollider2D> -> Option D
  4. Quick Check:

    AddComponent needs () to work [OK]
Hint: Always add () after AddComponent<Type> [OK]
Common Mistakes:
  • Forgetting parentheses after AddComponent
  • Confusing size property with other collider types
  • Using Vector3 instead of Vector2 for 2D colliders
5. You want to create a complex-shaped 2D character with both circular and polygonal parts. Which approach correctly combines colliders for best collision detection?
hard
A. Add multiple Collider2D components: CircleCollider2D for round parts and PolygonCollider2D for complex parts
B. Use only a single PolygonCollider2D for the entire character
C. Use only CircleCollider2D colliders and ignore polygon shapes
D. Add a BoxCollider2D and scale it to cover all parts

Solution

  1. Step 1: Understand collider combination

    Unity allows multiple Collider2D components on one GameObject for complex shapes.
  2. Step 2: Match collider types to shape parts

    Use CircleCollider2D for round parts and PolygonCollider2D for complex shapes to get accurate collisions.
  3. Step 3: Avoid oversimplifying with one collider

    Single collider types may not fit all parts well, causing inaccurate collisions.
  4. Final Answer:

    Add multiple Collider2D components: CircleCollider2D for round parts and PolygonCollider2D for complex parts -> Option A
  5. Quick Check:

    Combine colliders for complex shapes [OK]
Hint: Use multiple colliders for mixed shapes [OK]
Common Mistakes:
  • Trying to use one collider type for all shapes
  • Ignoring collider overlap and physics impact
  • Scaling box collider to fit complex shapes