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
Particle collision
📖 Scenario: You are creating a simple Unity scene where particles move and collide with each other. You want to detect when two particles collide and print a message.
🎯 Goal: Build a Unity script that detects collisions between particles and prints a message when a collision happens.
📋 What You'll Learn
Create a Unity script with a ParticleCollision class
Add a OnParticleCollision method to detect collisions
Print a message when a collision occurs
💡 Why This Matters
🌍 Real World
Particle collision detection is used in games and simulations to create interactive effects like explosions, sparks, or damage.
💼 Career
Understanding particle collisions is important for game developers and simulation programmers to create realistic and engaging visual effects.
Progress0 / 4 steps
1
Create the ParticleCollision class
Create a public class called ParticleCollision that inherits from MonoBehaviour.
Unity
Hint
Remember to include using UnityEngine; at the top.
2
Add the OnParticleCollision method
Inside the ParticleCollision class, add a public method called OnParticleCollision that takes a GameObject parameter named other.
Unity
Hint
This method is called automatically by Unity when a particle collides with another object.
3
Print a collision message
Inside the OnParticleCollision method, add a line to print the message "Particle collided with " followed by the other object's name using Debug.Log.
Unity
Hint
Use Debug.Log to print messages to the Unity Console.
4
Test the collision message output
Write a line to print "Particle collided with Enemy" to simulate the collision message output.
Unity
Hint
This simulates what Unity would print when a collision happens with an object named "Enemy".
Practice
(1/5)
1. What is the main purpose of the OnParticleCollision method in Unity's particle system?
easy
A. To stop the particle system from playing
B. To change the color of particles over time
C. To emit new particles continuously
D. To detect when particles collide with other objects
Solution
Step 1: Understand the role of OnParticleCollision
This method is a special Unity callback triggered when particles hit other objects in the scene.
Step 2: Identify its main use
It is used to detect collisions of particles, allowing you to respond to those events in code.
Final Answer:
To detect when particles collide with other objects -> Option D
Quick Check:
Particle collision detection = To detect when particles collide with other objects [OK]
What will happen when particles collide with another object named "Wall"?
medium
A. The console will print: Hit: Wall
B. The particle system will stop emitting
C. Nothing will happen because OnParticleCollision is not called
D. An error will occur because other.name is invalid
Solution
Step 1: Understand the method behavior
When particles hit an object, OnParticleCollision is called with that object as other.
Step 2: Analyze the Debug.Log statement
The code prints "Hit: " plus the name of the collided object, which is "Wall".
Final Answer:
The console will print: Hit: Wall -> Option A
Quick Check:
Collision triggers log with object name = The console will print: Hit: Wall [OK]
Hint: OnParticleCollision logs object name on hit [OK]
Common Mistakes:
Assuming particle system stops on collision
Thinking method is never called
Believing other.name is invalid
4. Given this code snippet in a Unity script:
void OnParticleCollision(GameObject other) {
int count = other.GetComponent<int>();
Debug.Log(count);
}
What is the problem with this code?
medium
A. OnParticleCollision must return a value
B. GetComponent<int>() is invalid because int is not a component
C. The method should use Collider instead of GameObject
D. Debug.Log cannot print integers
Solution
Step 1: Check GetComponent usage
GetComponent<T> expects a Component type, but int is a primitive type, not a component.
Step 2: Identify the error cause
Using GetComponent<int>() causes a compile-time error because int is invalid here.
Final Answer:
GetComponent<int>() is invalid because int is not a component -> Option B
Quick Check:
GetComponent requires Component type = GetComponent<int>() is invalid because int is not a component [OK]
Hint: GetComponent needs a Component type, not primitives [OK]
Common Mistakes:
Thinking OnParticleCollision must return a value
Confusing parameter type with Collider
Believing Debug.Log can't print integers
5. You want to reduce the damage caused by particles when they collide with enemies, but only if the enemy's health is above 50. Which approach correctly uses OnParticleCollision to achieve this?
hard
A. Check the particle system's emission rate and reduce damage if emission is low.
B. Use OnParticleCollision() without parameters and reduce damage always.
C. In OnParticleCollision(GameObject other), get the enemy's health component, check if health > 50, then reduce damage accordingly.
D. Use OnParticleCollision(Collider other) and reduce damage without checking health.
Solution
Step 1: Use correct method signature
The method must be OnParticleCollision(GameObject other) to get the collided object.
Step 2: Access enemy health and apply condition
Retrieve the health component from other, check if health > 50, then reduce damage only in that case.
Final Answer:
In OnParticleCollision(GameObject other), get the enemy's health component, check if health > 50, then reduce damage accordingly. -> Option C
Quick Check:
Conditional damage based on health = In OnParticleCollision(GameObject other), get the enemy's health component, check if health > 50, then reduce damage accordingly. [OK]
Hint: Check enemy health inside OnParticleCollision before damage [OK]