Version: Unity 6.5 (6000.5)
LanguageEnglish
  • C#

ShaderStageFlags

enumeration

Suggest a change

Success!

Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.

Close

Submission failed

For some reason your suggested change could not be submitted. Please <a>try again</a> in a few minutes. And thank you for taking the time to help us improve the quality of Unity Documentation.

Close

Cancel

Description

Represents one or several GPU shader stages.

This enum is used in various APIs that allow specifying multiple GPU shader stages simultaneuously. APIs that need to specify individual shader stages use the ShaderStage enum instead.

The traditional graphics shader stages used in rasterization are represented by the following enum values:

The compute shader stage and the ray tracing shader stage are represented as ShaderStageFlags.Compute and ShaderStageFlags.RayTracing, respectively.

In addition to that, the following enum values can be used for convenient representation of common shader stage combinations:

Use Utility.IsShaderStageEnabled to check if the ShaderStageFlags value has the given stage enabled. Utility.ShaderStageToFlags can be used to convert an individual shader stage to ShaderStageFlags.

Additional resources: ShaderStage, Utility.

using UnityEngine;
using UnityEngine.Shaders;

/*
    Attach this script to a GameObject and enter Play mode. "Shader stages: Basic, Tessellation" will be printed in the console.
*/

public class ShaderTypes : MonoBehaviour
{
    void Start()
    {
        ShaderStageFlags stages = (ShaderStageFlags.Graphics & (~ShaderStageFlags.Geometry));
        // Iterate over all possible shader stages and check if the only stages enabled are Vertex, Fragment, Hull, and Domain
        // Log a message if a stage is enabled or disabled incorrectly.
        for (ShaderStage stage = ShaderStage.FirstStage; stage < ShaderStage.Count; ++stage)
        {
            bool shouldBeEnabled = stage < ShaderStage.GraphicsStageCount && stage != ShaderStage.Geometry;
            if (Utility.IsShaderStageEnabled(stages, stage) != shouldBeEnabled)
                Debug.Log("Unexpected stage " + stage + (shouldBeEnabled ? " not enabled" : " enabled"));
        }
        Debug.Log("Shader stages: " + stages);
    }
}

Properties

Property Description
NoneSpecifies that no shader stages are enabled.
VertexSpecifies that vertex shader stage is enabled.
FragmentSpecifies that fragment shader stage is enabled.
HullSpecifies that hull shader stage is enabled.
DomainSpecifies that domain shader stage is enabled.
GeometrySpecifies that geometry shader stage is enabled.
ComputeSpecifies that compute shader stage is enabled.
RayTracingSpecifies that ray tracing shader stage is enabled.
BasicSpecifies that vertex and fragment shader stages are enabled.
TessellationSpecifies that hull and domain shader stages are enabled.
GraphicsSpecifies that vertex, fragment, geometry, hull, and domain shader stages are enabled.
AnySpecifies that all shader stages are enabled.