You can create shadersA program that runs on the GPU. More info
See in Glossary that share some common code, but have different functionality when a given keyword is enabled or disabled.
Internally, shader keywords work by creating shader variants. Before you use shader keywords, it is important to understand how shader variants work, and the potential impact on performance and workflow. For information on this topic, 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.
You declare shader keywords in sets. A set contains mutually exclusive keywords.
For example, the following set contains three keywords:
Internally, shader keywords use #define
preprocessor directives. When you declare a set of shader keywords, Unity compiles shader variants with matching #define
directives.
Note: In Shader Graph, the terminology is different: a set of keywords is called a Keyword, and the keywords in a set are called states. Internally, the functionality is the same: Unity compiles them in the same way, you work with them the same way with C# scriptsA piece of code that allows you to create your own Components, trigger game events, modify Component properties over time and respond to user input in any way you like. More info
See in Glossary, and so on.
The number of keywords that you declare and the way that you declare these keywords has a significant impact on the number of shader variants that Unity compiles, which in turn can have a significant effect on the performance of your project and application. For more information, see Shader variants.
To declare keywords in hand-coded shaders, see Declaring and using shader keywords in HLSL. To declare keywords in Shader Graph shaders, see Keywords.
When you declare a set of keywords, you choose whether the keywords in the set have local or global scope.
Global and local keywords are separate: global keywords affect the whole project, and local keywords are specific to an individual shader.
Unless you are planning to enable keywords for multiple shaders at the same time, you should generally declare keywords with local scope.
To set this value in hand-coded shaders, see Declaring and using shader keywords in HLSL. To set this value in Shader Graph shaders, see Keywords. For information on enabling and disabling local and global shader keywords, see Using shader keywords with C# scripts.
Note: If there are global and local keywords with the same name, Unity prioritises the local keyword.
Warning: If a material has a local keyword enabled, and its shader changes to one that is no longer declared, Unity creates a new global keyword.
When you declare a set of keywords, you choose the technique that Unity uses to define them. This affects the number of shader variants that Unity compiles.
Which option is best depends on how you use the keywords. If you use the keywords to configure materials in your project and do not change their value from C# scripts at runtime, then you should use “shader feature” to reduce the number of shader keywords and variants in your project. If you enable and disable keywords at runtime using C# scripts, then you should use “multi compile” to prevent variants being stripped in error. For more information on shader stripping, see Stripping shader variants.
To set this value in hand-coded shaders, see Declaring and using shader keywords in HLSL. To set this value in Shader Graph shaders, see Keywords.
By default, Unity generates keyword variants for each stage of your shader. For example, if your shader contains a vertex stage and a fragment stage, Unity generates variants for every keyword combination for both the vertex and the fragment shader programs. If a set of keywords is only used in one of those stages, this results in identical variants for the other stage. Unity automatically identifies and deduplicates identical variants so that they do not increase build size, but they still result in wasted compilation time, increased shader loading times, and increased runtime memory usage.
To avoid this problem, when you declare a set of keywords in a hand-coded shader, you can instruct Unity to compile them only for a given shader stage.
Note: You are responsible for ensuring that the keywords are only used in the specified shader stages.
Unity does not fully support the use of stage-specific keyword directives for the following graphics APIs:
To set this value in hand-coded shaders, see Declaring and using shader keywords in HLSL. You cannot change this value in Shader Graph; by default, all keywords affect all stages.
You can mark sections of your shader source file so that Unity only includes that functionality in variants that are used when a given keyword is enabled.
The way that you do this is different in hand-coded shaders and in Shader Graph. For instructions for hand-coded shaders, see Defining and using shader keywords. For instructions for Shader Graph, see Shader Graph: Keyword Node.
You can enable or disable shader keywords. When you enable or disable a shader keyword, Unity uses the appropriate shader variant for rendering.
There are two ways to enable and disable shader keywords:
Unity uses predefined sets of shader keywords to enable common functionality. It adds the following sets of shader keywords at compile time:
There is a limit of 384 global shader keywords, and Unity uses around 60 of them internally (therefore lowering the available number). Each individual shader has a limit of 64 local keywords.
Every keyword declared in the shader source file and its dependenciesIn the context of the Package Manager, a dependency is a specific package version (expressed in the form package_name@package_version
) that a project or another package requires in order to work. Projects and packages use the dependencies attribute in their manifests to define the set of packages they require. For projects, these are considered direct dependencies; for packages, these are indirect, or transitive, dependencies. More info
See in Glossary
count towards these limits. Dependencies include Passes that the shader includes using UsePass, and fallbacks.
If Unity encounters a shader keyword with the same name multiple times, it only counts towards the limit once.
When you visit any website, it may store or retrieve information on your browser, mostly in the form of cookies. This information might be about you, your preferences or your device and is mostly used to make the site work as you expect it to. The information does not usually directly identify you, but it can give you a more personalized web experience. Because we respect your right to privacy, you can choose not to allow some types of cookies. Click on the different category headings to find out more and change our default settings. However, blocking some types of cookies may impact your experience of the site and the services we are able to offer.
More information
These cookies enable the website to provide enhanced functionality and personalisation. They may be set by us or by third party providers whose services we have added to our pages. If you do not allow these cookies then some or all of these services may not function properly.
These cookies allow us to count visits and traffic sources so we can measure and improve the performance of our site. They help us to know which pages are the most and least popular and see how visitors move around the site. All information these cookies collect is aggregated and therefore anonymous. If you do not allow these cookies we will not know when you have visited our site, and will not be able to monitor its performance.
These cookies may be set through our site by our advertising partners. They may be used by those companies to build a profile of your interests and show you relevant adverts on other sites. They do not store directly personal information, but are based on uniquely identifying your browser and internet device. If you do not allow these cookies, you will experience less targeted advertising. Some 3rd party video providers do not allow video views without targeting cookies. If you are experiencing difficulty viewing a video, you will need to set your cookie preferences for targeting to yes if you wish to view videos from these providers. Unity does not control this.
These cookies are necessary for the website to function and cannot be switched off in our systems. They are usually only set in response to actions made by you which amount to a request for services, such as setting your privacy preferences, logging in or filling in forms. You can set your browser to block or alert you about these cookies, but some parts of the site will not then work. These cookies do not store any personally identifiable information.