Version: 2021.2
Shaders introduction
Shader assets

The Shader class

In Unity, when you work with shaders that are part of the graphics pipeline, you usually work with instances of the ShaderA program that runs on the GPU. More info
See in Glossary
class. An instance of the Shader class is called a Shader object.

A Shader object is a Unity-specific way of working with shader programs; it is a wrapper for shader programs and other information. It lets you define multiple shader programs in the same file, and tell Unity how to use them.

Render pipeline compatibility

Feature name Built-in Render PipelineA series of operations that take the contents of a Scene, and displays them on a screen. Unity lets you choose from pre-built render pipelines, or write your own. More info
See in Glossary
Universal Render Pipeline (URP) High Definition Render Pipeline (HDRP) Custom SRP
Shader objects Yes Yes Yes Yes

Shader object fundamentals

A Shader object contains shader programs, instructions for changing settings on the GPU (collectively called the render state), and information that tells Unity how to use them.

You use Shader objects with materialsAn asset that defines how a surface should be rendered. More info
See in Glossary
to determine the appearance of your sceneA Scene contains the environments and menus of your game. Think of each unique Scene file as a unique level. In each Scene, you place your environments, obstacles, and decorations, essentially designing and building your game in pieces. More info
See in Glossary
.

Assets

You can create Shader objects in two ways. Each has its own type of asset:

Whichever way you create your Shader object, Unity represents the results in the same way internally.

Inside a Shader object

A Shader object has a nested structure. It organizes information into structures called SubShaders and Passes. It organises shader programs into shader variants.

Shader object

A Shader object contains:

  • Information about itself, such its name
  • An optional fallback Shader object, which Unity uses if it can’t use this one
  • One or more SubShaders

You can also define additional information such as shared shader code, or whether to use a custom editor. For information on defining a Shader object, see ShaderLab: defining a Shader object.

SubShaders

SubShaders let you separate your Shader object into parts that are compatible with different hardware, render pipelines, and runtime settings.

A SubShader contains:

  • Information about which hardware, render pipelines, and runtime settings this SubShader is compatible with
  • SubShader tags, which are key-value pairs that provide information about the SubShader
  • One or more Passes

You can also define additional information, such as render state that is common to all of its Passes. For information on everything you can define in a SubShader, see ShaderLab: defining a SubShader.

Passes

A Pass contains:

  • Pass tags, which are key-value pairs that provide information about the Pass
  • Instructions for updating the render state before running its shader programs
  • Shader programs, organised into one or more shader variants

You can also define additional information such as a name. For information on everything you can define in a Pass, see ShaderLab: defining a Pass.

Shader variants

The shader programs that a Pass contains are organised into shader variants. Shader variants share common code, but have different functionality when a given keyword is enabled or disabled.

The number of shader variants in a Pass depends on how many keywords you define in your shader code, and the target platform. Each Pass contains at least one variant.

For more information, see Shader variantsA verion of a shader program that Unity generates according to a specific combination of shader keywords and their status. A Shader object can contain multiple shader variants. More info
See in Glossary
.

Order of operations during rendering

This is a high-level description of how Unity uses Shader objects to render geometry, in all render pipelines.

Before Unity uses a Shader object:

  1. Unity creates a list of SubShaders for the Shader object. It adds all of the SubShaders defined in the Shader object, and then adds all of the SubShaders in any fallback Shader objects, in order.

When Unity first renders geometry using the Shader object, or when the shader LOD value or active render pipeline changes:

  1. Unity iterates over the list of all SubShaders and examines them to determine if they are: compatible with the device hardware; at or below the current shader LODThe Level Of Detail (LOD) technique is an optimization that reduces the number of triangles that Unity has to render for a GameObject when its distance from the Camera increases. More info
    See in Glossary
    value; and compatible with the active render pipeline.
  2. If the list contains one or more SubShaders that meet these requirements, it selects the first one. This is the active SubShader.
  3. If the list does not contain any SubShaders that meet all of the requirements:
    1. If the list contains one or more SubShaders that meet the hardware requirements (but do not meet the LOD or render pipeline requirements), Unity selects the first one. This is the active SubShader.
    2. If the list does not contain any SubShaders that meet the hardware requirements, Unity displays the error shader.

Unity can identify geometry that uses the same shader variant and organize it into batches for more efficient rendering. Once per frame, for every batch of geometry:

  1. Unity determines which of the Passes in the active SubShader it should render, and at which point in the frame. This behavior varies by render pipeline.
  2. For every Pass that it renders:
    1. If the current render state does not match the render state defined in the Pass, Unity sets the render state as defined in the Pass.
    2. The GPU renders the geometry using the relevant shader variant.
Shaders introduction
Shader assets