Version: 2022.1
언어: 한국어
셰이더 키워드와 C# 스크립트 함께 사용
셰이더 배리언트 스트리핑

셰이더 키워드와 머티리얼 인스펙터 함께 사용

Unity 에디터에서는 머티리얼 인스펙터에서 머티리얼을 확인할 때 머티리얼의 로컬 셰이더 키워드를 활성화하거나 비활성화할 수 있습니다. 이 기능은 다음 두 가지 이유에서 유용합니다.

  • 아티스트가 코드를 사용하지 않고도 다수의 키워드에 여러 키워드 값을 간편하게 설정할 수 있습니다.
  • [KeywordEnum] MaterialPropertyDrawer를 사용하여 키워드를 활성화하면, Unity가 세트의 다른 키워드를 자동으로 비활성화합니다. 이를 통해 언제든지 하나의 세트에서 정확히 하나의 키워드만 활성화되도록 보장할 수 있습니다.

여느 셰이더 설정 또는 데이터와 마찬가지로, 셰이더 키워드는 셰이더 소스 파일에서 머티리얼 프로퍼티로 선언된 경우에만 머티리얼 인스펙터에서 사용할 수 있습니다.

셰이더 그래프에서 만든 셰이더의 경우, 기본적으로 머티리얼 프로퍼티가 키워드입니다. 즉, 이러한 설정은 머티리얼 인스펙터에서 자동으로 사용할 수 있습니다. 이를 변경하려면 Blackboard를 열고 Exposed 프로퍼티를 변경하십시오.

수동으로 코딩된 셰이더의 경우, ShaderLab 코드에 키워드 세트를 나타내는 머티리얼 프로퍼티가 정의되어 있는지 확인해야 합니다.머티리얼 프로퍼티의 유형은 ’Float’여야 하며, 인스펙터에 올바르게 노출하려면 [Toggle], [ToggleOff] 또는 [KeywordEnum] MaterialPropertyDrawer 속성을 사용해야 합니다.

Shader "Custom/ApplyEffectIfKeywordIsOn"
{
    Properties
    {
        // Display a toggle in the Material's Inspector window
            [Toggle] _Keyword ("Keyword", Float) = 0.0
    }

    SubShader
    {
        Pass
        {
            #pragma shader_feature _Keyword

            fixed4 frag(v2f i) :SV_Target
            {
                    #if _Keyword
                        // If _Keyword is on at build time, Unity creates a shader variant that uses the following code
                        ApplyEffect();
                    #endif
            
            // rest of shader code...
            }
        }
    }
}

자세한 정보와 예시는 MaterialPropertyDrawer API 문서를 참조하십시오.

셰이더 키워드와 C# 스크립트 함께 사용
셰이더 배리언트 스트리핑