Shader objects can contain of hundreds or thousands of 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. If the Editor compiled all variants when loading a ShaderA program that runs on the GPU. More info See in Glossary object, the import process would be very slow. Instead, the Editor compiles shader variants on-demand, the first time it encounters them.
Compiling these shader variants can cause the Editor to stall for milliseconds or even seconds, depending on the graphics API and the complexity of the Shader objectAn instance of the Shader class, a Shader object is container for shader programs and GPU instructions, and information that tells Unity how to use them. Use them with materials to determine the appearance of your scene. More info See in Glossary. To avoid these stalls, you can use asynchronous shader compilation to compile the shader variants in the background, and use placeholder Shader objects in the meantime.
How asynchronous shader compilation works
Asynchronous shader compilation works like this:
When the Editor first encounters an uncompiled shader variant, it adds the shader variant to a compilation queue on a job thread. The progress bar in the bottom right corner of the Editor shows the status of the compilation queue.
While the shader variant is loading, Editor renders the geometry with a placeholder shader, which appears as a plain cyan color.
When the Editor has finished compiling the shader variant, it renders the geometry using the shader variant.
Exceptions
The following exceptions apply:
If you draw geometry using DrawProcedural or CommandBuffer.DrawProcedural, the Editor doesn’t use a placeholder shader. Instead, the Editor just skips rendering this geometry until it has compiled the shader variant.
The Unity Editor does not use asynchronous shader compilation with BlitA shorthand term for “bit block transfer”. A blit operation is the process of transferring blocks of data from one place in memory to another. See in Glossary operations. This is to guarantee correct output in the most common use cases.