Version: 2022.2

FilterAttribute

class in UnityEditor.ShaderKeywordFilter

切换到手册

描述

Tell the shader system which shader keywords to include or remove from the build, based on the data field underneath.

This is the base filter attribute class. Use the derived attributes instead: SelectIfAttribute SelectIfNotAttribute RemoveIfAttribute RemoveIfNotAttribute SelectOrRemoveAttribute RemoveOrSelectAttribute These filter attributes only apply to the build if they're attached to a serialized data field that's part of the type tree of a RenderPipelineAsset referenced by QualitySettings. The attributes give you control over which shader keywords Unity uses to build shader variants, based on render pipeline settings.

For example, by default the following shader code generates four different shader variants during the build:

#pragma multi_compile __ SHADOWS_LOW SHADOWS_MEDIUM SHADOWS_HIGH

If you use filter attributes, this can be adjusted to better suit the settings configuration of the project.

In the following example, when forceLowShadows is true, the SelectIf filter attribute forces the multi_compile keyword set to only contain the SHADOWS_LOW variant during the build.

using UnityEditor.ShaderKeywordFilter;

[SelectIf(true, keywordNames: "SHADOWS_LOW")] bool forceLowShadows;

You can also exclude keywords from the build. In the following example, when enableHighShadows is false, the RemoveIf filter attribute removes SHADOWS_HIGH.

[RemoveIf(false, keywordNames: "SHADOWS_HIGH")]
bool enableHighShadows;

You can also select or remove more than one keyword at a time.

In the following example, when onlyHighOrNoShadows is true, the SelectIf filter attribute selects only the SHADOWS_HIGH variant and a no shadows variant.

The empty string "" denotes the empty keyword. You can only select and remove the empty keyword together with another keyword, because "" on its own applies to all multi_compile keyword sets with an empty keyword.

[SelectIf(true, keywordNames: new string[] {"", "SHADOWS_HIGH"})]
bool onlyHighOrNoShadows;

You can use RemoveIfNot with enum data. The following example removes the SHADOWS_LOW variant if shadowMode is set to anything except Low.

public enum ShadowMode
{
    Low,
    Med,
    High
}

[RemoveIfNot(ShadowMode.Low, keywordNames: "SHADOWS_LOW")] ShadowMode shadowMode;

You can use the overridePriority argument to use filter attributes to override filtering you've previously set. Normally the first filter rule encountered in the type tree targeting a specific keyword takes effect, and Unity ignores any later attributes. If you use overridePriority, attributes can force the later filter rule to be active instead.

You can add constraint attributes to filter attributes, to determine whether the filter rule is active in the current context. See GraphicsAPIConstraintAttribute and TagConstraintAttribute for more information.

构造函数

FilterAttributeTell the shader system which shader keywords to include in or exclude from the build, based on the data field underneath.

对文档有任何疑问,请移步至开发者社区提问,我们将尽快为您解答
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961