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
Recall & Review
beginner
What is a Canvas in Unity UI?
A Canvas is a special GameObject in Unity that acts as a container for all UI elements. It controls how UI elements are rendered and displayed on the screen.
Click to reveal answer
beginner
Name the three render modes available for a Canvas in Unity.
The three render modes are: Screen Space - Overlay, Screen Space - Camera, and World Space.
Click to reveal answer
beginner
Describe Screen Space - Overlay render mode.
In Screen Space - Overlay mode, the Canvas renders UI elements directly on top of the screen. It ignores cameras and always appears in front of everything else.
Click to reveal answer
intermediate
How does Screen Space - Camera render mode work?
Screen Space - Camera mode renders UI elements using a specific camera. The UI is placed in the camera's view and can be affected by camera settings like perspective and depth.
Click to reveal answer
intermediate
What is World Space render mode and when would you use it?
World Space mode places the Canvas as a 3D object in the scene. UI elements behave like normal objects and can be interacted with in the 3D world, useful for VR or in-game screens.
Click to reveal answer
Which Canvas render mode ignores the camera and always displays UI on top?
ANone
BScreen Space - Camera
CWorld Space
DScreen Space - Overlay
✗ Incorrect
Screen Space - Overlay renders UI directly on the screen, ignoring any camera.
In which render mode is the Canvas treated as a 3D object in the scene?
AWorld Space
BScreen Space - Overlay
CScreen Space - Camera
DNone
✗ Incorrect
World Space mode places the Canvas in the 3D world as a normal object.
Which render mode requires assigning a camera to render the UI?
AScreen Space - Overlay
BWorld Space
CScreen Space - Camera
DNone
✗ Incorrect
Screen Space - Camera mode uses a specific camera to render UI elements.
What happens if you set a Canvas to Screen Space - Camera but do not assign a camera?
AUI renders normally
BUI does not render
CUI renders in overlay mode
DCanvas converts to World Space
✗ Incorrect
Without a camera assigned, Screen Space - Camera mode cannot render UI.
Which Canvas render mode is best for UI that should always stay on top of the game view?
AScreen Space - Overlay
BScreen Space - Camera
CWorld Space
DNone
✗ Incorrect
Screen Space - Overlay ensures UI is always visible on top.
Explain the differences between the three Canvas render modes in Unity.
Think about how the UI is positioned and rendered relative to the camera and scene.
You got /3 concepts.
When would you choose World Space render mode over Screen Space modes for a Canvas?
Consider scenarios where UI is not just an overlay but part of the game environment.
You got /3 concepts.
Practice
(1/5)
1. What does the Screen Space - Overlay render mode do in a Unity Canvas?
easy
A. Draws UI elements directly on the screen, always visible on top.
B. Renders UI elements as part of the 3D world, affected by camera perspective.
C. Draws UI elements only when the game is paused.
D. Renders UI elements on a separate camera layer invisible to the main camera.
Solution
Step 1: Understand Screen Space - Overlay mode
This mode draws UI elements directly on the screen, ignoring the 3D world and camera.
Step 2: Compare with other modes
Other modes like Screen Space - Camera or World Space render UI differently, but Overlay is always on top and visible.
Final Answer:
Draws UI elements directly on the screen, always visible on top. -> Option A
Quick Check:
Overlay mode = UI always on screen [OK]
Hint: Overlay mode means UI is always on top of everything [OK]
Common Mistakes:
Confusing Overlay with World Space mode
Thinking UI is affected by camera in Overlay mode
Assuming Overlay hides UI when paused
2. Which of the following is the correct way to set a Canvas to use the World Space render mode in C# script?
easy
A. canvas.renderMode = RenderMode.WorldSpace;
B. canvas.setRenderMode("WorldSpace");
C. canvas.RenderMode = "WorldSpace";
D. canvas.mode = RenderMode.WorldSpace;
Solution
Step 1: Recall Canvas renderMode property usage
In Unity C#, the Canvas component has a property called renderMode which is set using the RenderMode enum.
Step 2: Identify correct syntax
The correct syntax is canvas.renderMode = RenderMode.WorldSpace;. Other options use incorrect property names or methods.
Final Answer:
canvas.renderMode = RenderMode.WorldSpace; -> Option A
Quick Check:
Use enum RenderMode.WorldSpace for world space canvas [OK]
Hint: Use enum RenderMode.WorldSpace to set world space mode [OK]
Common Mistakes:
Using string instead of enum for renderMode
Wrong property name capitalization
Trying to call a method instead of setting property
The code sets canvas.renderMode to RenderMode.ScreenSpaceCamera.
Step 2: Understand Debug.Log output
Logging canvas.renderMode will print the enum name, which is "ScreenSpaceCamera".
Final Answer:
ScreenSpaceCamera -> Option C
Quick Check:
canvas.renderMode = ScreenSpaceCamera prints "ScreenSpaceCamera" [OK]
Hint: Debug.Log prints enum names as strings [OK]
Common Mistakes:
Expecting the camera name instead of renderMode
Confusing ScreenSpaceOverlay with ScreenSpaceCamera
Assuming null is printed if worldCamera is set
4. You have a Canvas set to RenderMode.WorldSpace but UI elements are not visible in the scene. What is the most likely cause?
medium
A. The UI elements are not children of the Canvas GameObject.
B. The Canvas renderMode should be set to ScreenSpaceOverlay for visibility.
C. The Canvas component is missing the CanvasScaler script.
D. The Canvas scale is too small or positioned outside the camera view.
Solution
Step 1: Understand World Space Canvas behavior
World Space Canvas acts like a 3D object, so scale and position affect visibility.
Step 2: Identify common visibility issues
If scale is too small or Canvas is outside camera view, UI won't be seen even if correctly set.
Final Answer:
The Canvas scale is too small or positioned outside the camera view. -> Option D
Quick Check:
World Space Canvas needs proper scale and position [OK]
Hint: Check Canvas scale and position in world space [OK]
Common Mistakes:
Thinking CanvasScaler is required for visibility
Assuming renderMode must be Overlay to see UI
Forgetting to parent UI elements to Canvas
5. You want a UI panel to appear fixed on the screen but also interact with a 3D object behind it using raycasts. Which Canvas render mode and setup should you use?
hard
A. Screen Space - Overlay with Graphic Raycaster blocking raycasts to 3D objects.
B. Screen Space - Camera with Canvas assigned to main camera and raycast target disabled on UI elements.
C. Screen Space - Camera with Canvas assigned to main camera and raycast blocking disabled.
D. World Space Canvas positioned in front of the camera with raycast target enabled on UI elements.
Solution
Step 1: Understand UI fixed on screen with 3D interaction
Screen Space - Camera mode allows UI to be fixed on screen but still respects camera perspective and raycasts.
Step 2: Setup for raycast interaction
Assign Canvas to main camera and disable raycast target on UI elements so raycasts pass through to 3D objects behind.
Final Answer:
Screen Space - Camera with Canvas assigned to main camera and raycast target disabled on UI elements. -> Option B
Quick Check:
Screen Space - Camera + raycast target = fixed UI + 3D interaction [OK]
Hint: Use Screen Space - Camera for fixed UI with 3D raycast [OK]
Common Mistakes:
Using Overlay mode which blocks all raycasts behind UI