Use the following recommended Graphics settings to optimize your builds for the Unity Web platform.
Find these settings under Edit > Project Settings > Graphics. For more information on each setting, refer to the details in Graphics.
Setting | Recommended setting | Description |
---|---|---|
Lightmap modes | Automatic (default) | Automatically strip variants that aren’t used. |
Fog modes | Automatic (default) | Automatically strip variants that aren’t used. |
Instancing Variants | Strip Unused (default) | Only include a shaderA program that runs on the GPU. More info See in Glossary variant if at least one material uses that variant. |
BatchRendererGroup Variants | Strip all | Removes all BatchRendererGroup shader variants. |
Always Included Shaders | Remove any shaders from this list that aren’t used in your project |
Use the LightmapA pre-rendered texture that contains the effects of light sources on static objects in the scene. Lightmaps are overlaid on top of scene geometry to create the effect of lighting. More info
See in Glossary Modes setting to change the shader variant stripping behavior for lightmap-related shaders. For examples of lightmap-related shader variants, refer to Graphics.
The recommended setting for each of these settings is Automatic (default), which removes any shader variants that aren’t used in your build. This setting is useful because if you don’t strip unused shaders, it can increase build times, file size and memory usage.
Use the Fog Modes setting to change the shader variant stripping behavior for shaders that relate to built-in Unity fog effect. For examples of fog shader variants and more information, refer to Graphics.
The recommended setting is Automatic (Default), which removes unused fog shaders from your build. It’s best to remove unused shaders because they can increase build times, file size and memory usage.
Use the Instancing Variants setting to change how much Unity should strip shader variants for GPU instancing. For more information, refer to Graphics.
The recommended setting is Strip Unused, which removes any instancing variant shaders that your project doesn’t use. It’s best to remove unused shaders because they can increase build times, file size and memory usage.
To keep some unused shaders for future use or for other shaders to reference them, choose Keep All instead.
Use the Batch renderer group variants setting to change the shader variant stripping behavior for shaders related to batch renderer groups (BRGs). For more information about BRGs, refer to BatchRendererGroup.
If your project doesn’t use BRGs, set Batch renderer group variants to Strip all, which removes all BRG shader variants. Unused shaders can increase build times, file size and memory usage. If your project uses BRGs, ignore this recommendation.
Always included shaders is a list of shaders for which Unity includes all possible variants in every build. If your project doesn’t use any of the shaders in the list, it’s best to remove them from the list because unused shaders can increase build times, file size and memory usage.
For more information, refer to Graphics.
To change the Always included shaders list via script instead, create a list of shaders you want to have in the list and assign it like this:
GraphicsSettings.alwaysIncludedShaders = newShadersList.ToArray();
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.