#include "Packages/com.unity.render-pipelines.universal/ShaderLibrary/UnityGBuffer.hlsl" // Structs struct Attributes { float4 positionOS : POSITION; float3 normalOS : NORMAL; float4 tangentOS : TANGENT; float2 texcoord : TEXCOORD0; float2 texcoord1 : TEXCOORD1; // Bending half4 color : COLOR; // Bending //float2 staticLightmapUV : TEXCOORD1; //float2 dynamicLightmapUV : TEXCOORD2; UNITY_VERTEX_INPUT_INSTANCE_ID }; struct Varyings { float2 uv : TEXCOORD0; #if defined(REQUIRES_WORLD_SPACE_POS_INTERPOLATOR) float3 positionWS : TEXCOORD1; #endif half3 normalWS : TEXCOORD2; #if defined(_NORMALMAP) half4 tangentWS : TEXCOORD3; #endif #ifdef _ADDITIONAL_LIGHTS_VERTEX half3 vertexLighting : TEXCOORD4; #endif #if defined(REQUIRES_VERTEX_SHADOW_COORD_INTERPOLATOR) float4 shadowCoord : TEXCOORD5; #endif //#if defined(REQUIRES_TANGENT_SPACE_VIEW_DIR_INTERPOLATOR) // half3 viewDirTS : TEXCOORD6; //#endif DECLARE_LIGHTMAP_OR_SH(staticLightmapUV, vertexSH, 6); //#ifdef DYNAMICLIGHTMAP_ON // float2 dynamicLightmapUV : TEXCOORD8; //#endif float4 positionCS : SV_POSITION; // #if defined(SHADER_STAGE_FRAGMENT) // FRONT_FACE_TYPE cullFace : FRONT_FACE_SEMANTIC; // #endif // CTI specific #if defined(CTIBARKARRAY) half3 occlusionVariation : TEXCOORD7; #else half2 occlusionVariation : TEXCOORD7; #endif //UNITY_VERTEX_INPUT_INSTANCE_ID UNITY_VERTEX_OUTPUT_STEREO }; //-------------------------------------- // Include the surface function #include "Includes/CTI URP Bark SurfaceData.hlsl" //-------------------------------------- // Vertex shader #include "Includes/CTI URP Bending.hlsl" Varyings LitGBufferPassVertex (Attributes input) { Varyings output = (Varyings)0; UNITY_SETUP_INSTANCE_ID(input); //UNITY_TRANSFER_INSTANCE_ID(input, output); UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(output); CTI_AnimateVertex( input, #if defined (_BENDINGCOLRSONLY) float4(input.color.rg, input.color.ab), // animParams, #else float4(input.color.rg, input.texcoord1.xy), // animParams, #endif _BaseWindMultipliers ); // CTI special #if defined(CTIBARKARRAY) output.occlusionVariation = input.color.arb; #else output.occlusionVariation = input.color.ar; #endif VertexPositionInputs vertexInput = GetVertexPositionInputs(input.positionOS.xyz); VertexNormalInputs normalInput = GetVertexNormalInputs(input.normalOS, input.tangentOS); output.uv = input.texcoord; //TRANSFORM_TEX(input.texcoord, _BaseMap); // Already normalized from normal transform to WS. output.normalWS = normalInput.normalWS; #ifdef _NORMALMAP real sign = input.tangentOS.w * GetOddNegativeScale(); output.tangentWS = half4(normalInput.tangentWS.xyz, sign); #endif //#if defined(REQUIRES_TANGENT_SPACE_VIEW_DIR_INTERPOLATOR) // half3 viewDirWS = GetWorldSpaceNormalizeViewDir(vertexInput.positionWS); // half3 viewDirTS = GetViewDirectionTangentSpace(tangentWS, output.normalWS, viewDirWS); // output.viewDirTS = viewDirTS; //#endif //OUTPUT_LIGHTMAP_UV(input.staticLightmapUV, unity_LightmapST, output.staticLightmapUV); //#ifdef DYNAMICLIGHTMAP_ON // output.dynamicLightmapUV = input.dynamicLightmapUV.xy * unity_DynamicLightmapST.xy + unity_DynamicLightmapST.zw; //#endif OUTPUT_SH(output.normalWS.xyz, output.vertexSH); #ifdef _ADDITIONAL_LIGHTS_VERTEX half3 vertexLight = VertexLighting(vertexInput.positionWS, normalInput.normalWS); output.vertexLighting = vertexLight; #endif //#if defined(REQUIRES_WORLD_SPACE_POS_INTERPOLATOR) output.positionWS = vertexInput.positionWS; //#endif #if defined(REQUIRES_VERTEX_SHADOW_COORD_INTERPOLATOR) output.shadowCoord = GetShadowCoord(vertexInput); #endif output.positionCS = vertexInput.positionCS; return output; } FragmentOutput LitGBufferPassFragment(Varyings input) { //UNITY_SETUP_INSTANCE_ID(input); UNITY_SETUP_STEREO_EYE_INDEX_POST_VERTEX(input); #if defined(LOD_FADE_CROSSFADE) && !defined(SHADER_API_GLES) LODDitheringTransition(input.positionCS.xyz, unity_LODFade.x); #endif SurfaceData surfaceData; // Get the surface description #if defined(CTIBARKARRAY) InitializeStandardLitSurfaceData(input.occlusionVariation.yz, input.uv.xy, surfaceData); #else InitializeStandardLitSurfaceData(input.occlusionVariation.y, input.uv.xy, surfaceData); #endif // Transfer all to world space InputData inputData = (InputData)0; inputData.positionWS = input.positionWS; half3 viewDirWS = GetWorldSpaceNormalizeViewDir(input.positionWS); #ifdef _NORMALMAP float sgn = input.tangentWS.w; float3 bitangent = sgn * cross(input.normalWS.xyz, input.tangentWS.xyz); inputData.normalWS = TransformTangentToWorld(surfaceData.normalTS, half3x3(input.tangentWS.xyz, bitangent.xyz, input.normalWS.xyz)); #else inputData.normalWS = input.normalWS; #endif inputData.normalWS = NormalizeNormalPerPixel(inputData.normalWS); inputData.viewDirectionWS = viewDirWS; #if defined(REQUIRES_VERTEX_SHADOW_COORD_INTERPOLATOR) inputData.shadowCoord = input.shadowCoord; #elif defined(MAIN_LIGHT_CALCULATE_SHADOWS) inputData.shadowCoord = TransformWorldToShadowCoord(inputData.positionWS); #else inputData.shadowCoord = float4(0, 0, 0, 0); #endif inputData.fogCoord = 0.0; // we don't apply fog in the guffer pass #ifdef _ADDITIONAL_LIGHTS_VERTEX inputData.vertexLighting = input.vertexLighting.xyz; #else inputData.vertexLighting = half3(0, 0, 0); #endif #if defined(DYNAMICLIGHTMAP_ON) inputData.bakedGI = SAMPLE_GI(input.staticLightmapUV, input.dynamicLightmapUV, input.vertexSH, inputData.normalWS); #else inputData.bakedGI = SAMPLE_GI(input.staticLightmapUV, input.vertexSH, inputData.normalWS); #endif inputData.normalizedScreenSpaceUV = GetNormalizedScreenSpaceUV(input.positionCS); inputData.shadowMask = SAMPLE_SHADOWMASK(input.staticLightmapUV); #ifdef _DBUFFER #if defined(_RECEIVEDECALS) ApplyDecalToSurfaceData(input.positionCS, surfaceData, inputData); #endif #endif BRDFData brdfData; InitializeBRDFData(surfaceData.albedo, surfaceData.metallic, surfaceData.specular, surfaceData.smoothness, surfaceData.alpha, brdfData); Light mainLight = GetMainLight(inputData.shadowCoord, inputData.positionWS, inputData.shadowMask); MixRealtimeAndBakedGI(mainLight, inputData.normalWS, inputData.bakedGI, inputData.shadowMask); half3 color = GlobalIllumination(brdfData, inputData.bakedGI, surfaceData.occlusion, inputData.positionWS, inputData.normalWS, inputData.viewDirectionWS); return BRDFDataToGbuffer(brdfData, inputData, surfaceData.smoothness, surfaceData.emission + color, surfaceData.occlusion); }