Bird
Raised Fist0
Unityframework~10 mins

Color and size over lifetime in Unity - Interactive Code Practice

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
Practice - 5 Tasks
Answer the questions below
1fill in blank
easy

Complete the code to set the particle system's start color to red.

Unity
var ps = GetComponent<ParticleSystem>();
var main = ps.main;
main.startColor = [1];
Drag options to blanks, or click blank then click option'
AColor.red
BColor.yellow
CColor.green
DColor.blue
Attempts:
3 left
💡 Hint
Common Mistakes
Using a color other than red.
Forgetting to access the main module.
2fill in blank
medium

Complete the code to enable size over lifetime module.

Unity
var ps = GetComponent<ParticleSystem>();
var sizeOverLifetime = ps.sizeOverLifetime;
sizeOverLifetime.[1] = true;
Drag options to blanks, or click blank then click option'
AstartColor
Benabled
CstartSize
DplayOnAwake
Attempts:
3 left
💡 Hint
Common Mistakes
Using startSize which is not a property of the module.
Trying to set startColor here.
3fill in blank
hard

Fix the error in setting the color gradient for color over lifetime.

Unity
var ps = GetComponent<ParticleSystem>();
var colorOverLifetime = ps.colorOverLifetime;
colorOverLifetime.enabled = true;
colorOverLifetime.color = new ParticleSystem.MinMaxGradient([1]);
Drag options to blanks, or click blank then click option'
AColor.blue
BColor.green
CColor.red
Dnew Gradient()
Attempts:
3 left
💡 Hint
Common Mistakes
Passing a Color directly instead of a Gradient.
Not enabling the module before setting color.
4fill in blank
hard

Fill both blanks to set size over lifetime curve and enable it.

Unity
var ps = GetComponent<ParticleSystem>();
var sizeOverLifetime = ps.sizeOverLifetime;
sizeOverLifetime.[1] = new ParticleSystem.MinMaxCurve(AnimationCurve.EaseInOut(0, 0, 1, 1));
sizeOverLifetime.[2] = true;
Drag options to blanks, or click blank then click option'
Asize
Benabled
CstartSize
Dcolor
Attempts:
3 left
💡 Hint
Common Mistakes
Using startSize which is not a property here.
Forgetting to enable the module.
5fill in blank
hard

Fill all three blanks to set a color gradient with two color keys and enable color over lifetime.

Unity
var ps = GetComponent<ParticleSystem>();
var colorOverLifetime = ps.colorOverLifetime;
var gradient = new Gradient();
gradient.colorKeys = new GradientColorKey[] {
    new GradientColorKey([1], 0.0f),
    new GradientColorKey([2], 1.0f)
};
gradient.alphaKeys = new GradientAlphaKey[] {
    new GradientAlphaKey(1.0f, 0.0f),
    new GradientAlphaKey(0.0f, 1.0f)
};
colorOverLifetime.color = new ParticleSystem.MinMaxGradient(gradient);
colorOverLifetime.[3] = true;
Drag options to blanks, or click blank then click option'
AColor.yellow
BColor.red
Cenabled
DColor.blue
Attempts:
3 left
💡 Hint
Common Mistakes
Swapping the color keys' order.
Not enabling the color over lifetime module.

Practice

(1/5)
1. What does the ColorOverLifetime module do in Unity's Particle System?
easy
A. It adjusts the size of particles instantly.
B. It changes the color of particles smoothly as they age.
C. It controls the speed of particles over time.
D. It sets the initial color of particles only.

Solution

  1. Step 1: Understand the purpose of ColorOverLifetime

    The ColorOverLifetime module is designed to modify particle colors gradually as they live.
  2. Step 2: Compare options with module function

    Only It changes the color of particles smoothly as they age. correctly describes this smooth color change over particle lifetime.
  3. Final Answer:

    It changes the color of particles smoothly as they age. -> Option B
  4. Quick Check:

    ColorOverLifetime = Smooth color change [OK]
Hint: ColorOverLifetime changes colors gradually over particle life [OK]
Common Mistakes:
  • Confusing ColorOverLifetime with initial color setting
  • Thinking it controls size or speed
  • Assuming it changes color instantly
2. Which of the following is the correct way to enable the SizeOverLifetime module in a Unity Particle System script?
easy
A. particleSystem.sizeoverlifetime.enabled = true;
B. particleSystem.SizeOverLifetime.enabled = true;
C. particleSystem.sizeOverLifetime.enabled = true;
D. particleSystem.sizeOverLifetime.enable = true;

Solution

  1. Step 1: Check correct property casing and spelling

    Unity uses camelCase for properties, so sizeOverLifetime is correct.
  2. Step 2: Verify property names and boolean flags

    The property to enable is enabled, not enable.
  3. Final Answer:

    particleSystem.sizeOverLifetime.enabled = true; -> Option C
  4. Quick Check:

    Correct casing and property name = particleSystem.sizeOverLifetime.enabled = true; [OK]
Hint: Use camelCase and 'enabled' property to activate modules [OK]
Common Mistakes:
  • Incorrect capitalization of 'sizeOverLifetime'
  • Using 'enable' instead of 'enabled'
  • Misspelling the module name
3. Given this code snippet in Unity:
var ps = GetComponent<ParticleSystem>();
var col = ps.colorOverLifetime;
col.enabled = true;
col.color = new ParticleSystem.MinMaxGradient(Color.red, Color.blue);
What will happen to the particles' colors over their lifetime?
medium
A. Particles will smoothly change color from red to blue as they age.
B. Particles will stay red throughout their life.
C. Particles will instantly switch from red to blue at half their lifetime.
D. Particles will not change color because the gradient is invalid.

Solution

  1. Step 1: Analyze the colorOverLifetime setup

    The code enables colorOverLifetime and sets a gradient from red to blue.
  2. Step 2: Understand gradient effect on particles

    This gradient causes particles to smoothly transition from red at birth to blue at death.
  3. Final Answer:

    Particles will smoothly change color from red to blue as they age. -> Option A
  4. Quick Check:

    Gradient red to blue = smooth color change [OK]
Hint: Gradient from color A to B means smooth transition over lifetime [OK]
Common Mistakes:
  • Assuming color stays constant
  • Thinking color changes instantly
  • Believing gradient is invalid without alpha
4. Identify the error in this Unity C# code for SizeOverLifetime:
var ps = GetComponent<ParticleSystem>();
var size = ps.sizeOverLifetime;
size.enabled = true;
size.size = new ParticleSystem.MinMaxCurve(1.0f, 0.0f);
medium
A. MinMaxCurve cannot have start value greater than end value.
B. The size curve should be assigned using a curve, not MinMaxCurve.
C. The MinMaxCurve constructor parameters are reversed; it should be (0.0f, 1.0f).
D. There is no error; the code shrinks particles from size 1 to 0 correctly.

Solution

  1. Step 1: Review MinMaxCurve usage for size

    MinMaxCurve can define a linear change from start to end size; start larger than end is valid.
  2. Step 2: Confirm code logic

    The code enables sizeOverLifetime and sets size to shrink from 1.0 to 0.0, which is correct.
  3. Final Answer:

    There is no error; the code shrinks particles from size 1 to 0 correctly. -> Option D
  4. Quick Check:

    Shrinking size from 1 to 0 is valid [OK]
Hint: Start size can be bigger than end size for shrinking effect [OK]
Common Mistakes:
  • Thinking start value must be less than end value
  • Confusing MinMaxCurve with animation curve
  • Assuming reversed parameters cause error
5. You want particles to start fully transparent, become fully visible halfway through their life, then fade out again by the end. How can you set this using ColorOverLifetime in Unity?
hard
A. Use a gradient with alpha keys at 0 (0), 0.5 (1), and 1 (0) to control transparency over lifetime.
B. Set the start color alpha to 0 and end color alpha to 1 in ColorOverLifetime gradient.
C. Enable SizeOverLifetime and animate size from 0 to 1 to 0 to control visibility.
D. Use a single color with alpha 1 and animate particle emission rate.

Solution

  1. Step 1: Understand alpha control with ColorOverLifetime

    Alpha keys in gradient let you control transparency at different life points.
  2. Step 2: Set gradient alpha keys for fade in and fade out

    Alpha 0 at start, 1 at half life, and 0 at end creates the desired transparency effect.
  3. Final Answer:

    Use a gradient with alpha keys at 0 (0), 0.5 (1), and 1 (0) to control transparency over lifetime. -> Option A
  4. Quick Check:

    Alpha keys control transparency fade in/out [OK]
Hint: Use alpha keys in gradient for fade in and fade out [OK]
Common Mistakes:
  • Only setting start and end alpha without middle key
  • Using size to control transparency
  • Changing emission rate instead of color alpha