Bird
Raised Fist0
Unityframework~5 mins

Raycasting for detection in Unity

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
Introduction

Raycasting helps your game check if something is in front of an object. It works like shining a flashlight or laser to see what it hits.

To check if the player can see an enemy.
To detect if there is a wall in front before moving.
To find out if a bullet hits a target.
To interact with objects by pointing at them.
To check if the ground is below the player.
Syntax
Unity
Physics.Raycast(origin, direction, out RaycastHit hitInfo, maxDistance)

origin: where the ray starts (a point in space).

direction: the way the ray points (a vector).

Examples
This shoots a ray from the object forward up to 10 units and prints the name of what it hits.
Unity
if (Physics.Raycast(transform.position, transform.forward, out RaycastHit hit, 10f)) {
    Debug.Log("Hit: " + hit.collider.name);
}
This ray points down to check if the ground is within 5 units below.
Unity
Ray ray = new Ray(transform.position, Vector3.down);
if (Physics.Raycast(ray, out RaycastHit hitInfo, 5f)) {
    Debug.Log("Ground detected at distance: " + hitInfo.distance);
}
Sample Program

This script checks every frame if there is an object in front of the player within 10 units. It prints the object's name or says nothing is detected.

Unity
using UnityEngine;

public class RaycastDetector : MonoBehaviour {
    void Update() {
        if (Physics.Raycast(transform.position, transform.forward, out RaycastHit hit, 10f)) {
            Debug.Log($"Detected object: {hit.collider.name}");
        } else {
            Debug.Log("Nothing detected in front.");
        }
    }
}
OutputSuccess
Important Notes

Make sure objects you want to detect have colliders attached.

Raycasting only detects objects on layers that are not ignored by the raycast.

You can adjust maxDistance to control how far the ray checks.

Summary

Raycasting sends an invisible line to detect objects in a direction.

Use it to check for obstacles, targets, or interactable items.

Remember to set origin, direction, and max distance carefully.

Practice

(1/5)
1. What does raycasting do in Unity?
Raycast is often used to:
easy
A. Send an invisible line to detect objects in a direction
B. Create a visible laser beam effect
C. Change the color of an object
D. Play a sound when an object is clicked

Solution

  1. Step 1: Understand raycasting purpose

    Raycasting sends an invisible line (ray) from a point in a direction to detect objects.
  2. Step 2: Identify correct use

    It is used to check if something is hit by this invisible line, like obstacles or targets.
  3. Final Answer:

    Send an invisible line to detect objects in a direction -> Option A
  4. Quick Check:

    Raycasting = Detect objects with invisible line [OK]
Hint: Raycasting detects objects by sending invisible lines [OK]
Common Mistakes:
  • Thinking raycasting creates visible effects
  • Confusing raycasting with changing object properties
  • Assuming raycasting plays sounds
2. Which of the following is the correct way to start a raycast in Unity C#?
easy
A. Physics.CastRay(origin, direction, hit, maxDistance);
B. Physics.RayCast(origin, direction, hit, maxDistance);
C. Physics.Raycast(origin, direction, out hit, maxDistance);
D. Physics.Raycast(origin, direction, hit, maxDistance);

Solution

  1. Step 1: Recall correct method name and parameters

    The correct method is Physics.Raycast with parameters: origin, direction, out hit, maxDistance.
  2. Step 2: Check syntax correctness

    Only Physics.Raycast(origin, direction, out hit, maxDistance); uses the exact method name and includes out keyword for hit parameter.
  3. Final Answer:

    Physics.Raycast(origin, direction, out hit, maxDistance); -> Option C
  4. Quick Check:

    Correct method and out parameter = Physics.Raycast(origin, direction, out hit, maxDistance); [OK]
Hint: Remember 'out' keyword for hit in Physics.Raycast [OK]
Common Mistakes:
  • Misspelling method name as CastRay or RayCast
  • Omitting 'out' keyword for hit parameter
  • Passing hit without 'out' keyword
3. What will be the output of this code snippet?
RaycastHit hit;
if (Physics.Raycast(transform.position, transform.forward, out hit, 10f)) {
    Debug.Log(hit.collider.name);
} else {
    Debug.Log("No hit");
}

Assuming there is an object named "Target" 5 units ahead in the forward direction.
medium
A. "No hit"
B. "Target"
C. NullReferenceException
D. Empty string

Solution

  1. Step 1: Understand raycast parameters and scene setup

    The raycast starts at the object's position and goes forward 10 units. Since "Target" is 5 units ahead, it will be hit.
  2. Step 2: Analyze output

    Because the ray hits "Target", hit.collider.name will be "Target" and printed.
  3. Final Answer:

    "Target" -> Option B
  4. Quick Check:

    Ray hits object named Target = Output "Target" [OK]
Hint: If object is within distance, raycast hits it [OK]
Common Mistakes:
  • Assuming no hit if object is closer than maxDistance
  • Expecting error instead of hit name
  • Confusing hit.collider.name with hit.transform.name
4. Identify the error in this raycasting code:
RaycastHit hit;
if (Physics.Raycast(transform.position, transform.forward, hit, 10f)) {
    Debug.Log("Hit detected");
}
medium
A. Missing 'out' keyword before hit parameter
B. Wrong method name 'Raycast' should be 'CastRay'
C. transform.forward is invalid direction
D. RaycastHit cannot be used with Physics.Raycast

Solution

  1. Step 1: Check method signature

    Physics.Raycast requires the hit parameter to be passed with the 'out' keyword.
  2. Step 2: Identify missing keyword

    The code passes 'hit' without 'out', causing a compile error.
  3. Final Answer:

    Missing 'out' keyword before hit parameter -> Option A
  4. Quick Check:

    Missing 'out' causes error = Missing 'out' keyword before hit parameter [OK]
Hint: Always use 'out' before hit in Physics.Raycast [OK]
Common Mistakes:
  • Omitting 'out' keyword
  • Changing method name incorrectly
  • Using invalid direction vector
5. You want to detect only objects on the "Enemy" layer using raycasting. Which code snippet correctly does this?
hard
A. int layerMask = LayerMask.NameToLayer("Enemy"); if (Physics.Raycast(origin, direction, out hit, maxDistance, layerMask)) { // hit enemy }
B. int layerMask = 1 << LayerMask.NameToLayer("Enemy"); if (Physics.Raycast(origin, direction, out hit, maxDistance)) { // hit enemy }
C. int layerMask = 1 << LayerMask.NameToLayer("Player"); if (Physics.Raycast(origin, direction, out hit, maxDistance, layerMask)) { // hit enemy }
D. int layerMask = LayerMask.GetMask("Enemy"); if (Physics.Raycast(origin, direction, out hit, maxDistance, layerMask)) { // hit enemy }

Solution

  1. Step 1: Understand layer mask creation

    LayerMask.GetMask("Enemy") returns a mask for the "Enemy" layer correctly for raycasting.
  2. Step 2: Eliminate incorrect options

    int layerMask = 1 << LayerMask.NameToLayer("Enemy"); if (Physics.Raycast(origin, direction, out hit, maxDistance)) { // hit enemy } calculates the layer mask correctly but fails to pass it to the Raycast method, so it detects all layers. int layerMask = 1 << LayerMask.NameToLayer("Player"); if (Physics.Raycast(origin, direction, out hit, maxDistance, layerMask)) { // hit enemy } uses the "Player" layer mask instead of "Enemy". int layerMask = LayerMask.NameToLayer("Enemy"); if (Physics.Raycast(origin, direction, out hit, maxDistance, layerMask)) { // hit enemy } uses LayerMask.NameToLayer("Enemy") without bit shift, creating an invalid layer mask (index instead of bitmask).
  3. Final Answer:

    int layerMask = LayerMask.GetMask("Enemy"); if (Physics.Raycast(origin, direction, out hit, maxDistance, layerMask)) { // hit enemy } -> Option D
  4. Quick Check:

    Use LayerMask.GetMask for correct layer mask [OK]
Hint: Use LayerMask.GetMask("LayerName") for raycast layer filtering [OK]
Common Mistakes:
  • Using NameToLayer without bit shift
  • Using wrong layer name
  • Not applying layer mask in raycast