Standard_Specular_Snow.shader 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300
  1. Shader "NatureManufacture Shaders/Standard Shaders/Standard Specular Snow"
  2. {
  3. Properties
  4. {
  5. _MainTex("MainTex", 2D) = "white" {}
  6. _Color("Color", Color) = (1,1,1,1)
  7. _BumpMap("BumpMap", 2D) = "bump" {}
  8. _BumpScale("BumpScale", Range( 0 , 2)) = 1
  9. _SpecularRGBSmoothnesA("Specular (RGB) Smoothnes (A)", 2D) = "white" {}
  10. _SpecularPower("Specular Power", Range( 0 , 2)) = 1
  11. _SmoothnessPower("Smoothness Power", Range( 0 , 2)) = 1
  12. _AmbientOcclusionG("Ambient Occlusion (G)", 2D) = "white" {}
  13. _AmbientOcclusionPower("Ambient Occlusion Power", Range( 0 , 1)) = 1
  14. _DetailMask("DetailMask", 2D) = "white" {}
  15. _DetailAlbedoPower("Detail Albedo Power", Range( 0 , 2)) = 0
  16. _DetailAlbedoMap("DetailAlbedoMap", 2D) = "black" {}
  17. [NoScaleOffset]_DetailNormalMap("DetailNormalMap", 2D) = "bump" {}
  18. _DetailNormalMapScale("DetailNormalMapScale", Range( 0 , 5)) = 0
  19. [Toggle(_USESNOW_ON)] _UseSnow("Use Snow", Float) = 1
  20. [Toggle(_USEDYNAMICSNOWTSTATICMASKF_ON)] _UseDynamicSnowTStaticMaskF("Use Dynamic Snow (T) Static Mask (F)", Float) = 1
  21. _SnowMaskB("Snow Mask (B)", 2D) = "white" {}
  22. _SnowMaskPower("Snow Mask Power", Range( 0 , 10)) = 1
  23. _Snow_Amount("Snow_Amount", Range( 0 , 2)) = 0.13
  24. _Snow_AmountGrowSpeed("Snow_Amount Grow Speed", Range( 1 , 3)) = 2
  25. _TriplanarCoverFalloff("Triplanar Cover Falloff", Range( 1 , 100)) = 8
  26. _SnowAlbedoRGB("Snow Albedo (RGB)", 2D) = "white" {}
  27. _SnowTiling("Snow Tiling", Range( 0.0001 , 100)) = 15
  28. _SnowAlbedoColor("Snow Albedo Color", Color) = (1,1,1,1)
  29. _SnowNormalRGB("Snow Normal (RGB)", 2D) = "white" {}
  30. _SnowNormalScale("Snow Normal Scale", Range( 0 , 2)) = 1
  31. _SnowNormalCoverHardness("Snow Normal Cover Hardness", Range( 0 , 10)) = 1
  32. _Snow_SpecularRGBSmoothnessA("Snow_Specular (RGB) Smoothness (A)", 2D) = "white" {}
  33. _SnowSpecularPower("Snow Specular Power", Range( 0 , 2)) = 0
  34. _SnowSmoothnessPower("Snow Smoothness Power", Range( 0 , 2)) = 1
  35. _SnowAmbientOcclusionG("Snow Ambient Occlusion(G)", 2D) = "white" {}
  36. _SnowAmbientOcclusionPower("Snow Ambient Occlusion Power", Range( 0 , 1)) = 1
  37. _SnowMaxAngle("Snow Max Angle", Range( 0.001 , 90)) = 90
  38. _SnowHardness("Snow Hardness", Range( 1 , 10)) = 5
  39. _Snow_Min_Height("Snow_Min_Height", Range( -1000 , 10000)) = -1000
  40. _SnowHeightG("Snow Height (G)", 2D) = "white" {}
  41. _SnowHeightSharpness("Snow Height Sharpness", Range( 0 , 2)) = 0.3
  42. _Snow_Min_Height_Blending("Snow_Min_Height_Blending", Range( 0 , 500)) = 1
  43. [HideInInspector] _texcoord( "", 2D ) = "white" {}
  44. [HideInInspector] __dirty( "", Int ) = 1
  45. }
  46. SubShader
  47. {
  48. Tags{ "RenderType" = "Opaque" "Queue" = "Geometry+0" }
  49. Cull Back
  50. ZTest LEqual
  51. CGINCLUDE
  52. #include "UnityStandardUtils.cginc"
  53. #include "UnityPBSLighting.cginc"
  54. #include "Lighting.cginc"
  55. #pragma target 3.0
  56. #pragma shader_feature _USESNOW_ON
  57. #pragma shader_feature _USEDYNAMICSNOWTSTATICMASKF_ON
  58. #include "NM_indirect.cginc"
  59. #pragma multi_compile GPU_FRUSTUM_ON __
  60. #pragma instancing_options procedural:setup
  61. #ifdef UNITY_PASS_SHADOWCASTER
  62. #undef INTERNAL_DATA
  63. #undef WorldReflectionVector
  64. #undef WorldNormalVector
  65. #define INTERNAL_DATA half3 internalSurfaceTtoW0; half3 internalSurfaceTtoW1; half3 internalSurfaceTtoW2;
  66. #define WorldReflectionVector(data,normal) reflect (data.worldRefl, half3(dot(data.internalSurfaceTtoW0,normal), dot(data.internalSurfaceTtoW1,normal), dot(data.internalSurfaceTtoW2,normal)))
  67. #define WorldNormalVector(data,normal) half3(dot(data.internalSurfaceTtoW0,normal), dot(data.internalSurfaceTtoW1,normal), dot(data.internalSurfaceTtoW2,normal))
  68. #endif
  69. struct Input
  70. {
  71. float2 uv_texcoord;
  72. float3 worldPos;
  73. float3 worldNormal;
  74. INTERNAL_DATA
  75. };
  76. uniform float _BumpScale;
  77. uniform sampler2D _BumpMap;
  78. uniform sampler2D _MainTex;
  79. uniform float4 _MainTex_ST;
  80. uniform float _DetailNormalMapScale;
  81. uniform sampler2D _DetailNormalMap;
  82. uniform sampler2D _DetailAlbedoMap;
  83. uniform float4 _DetailAlbedoMap_ST;
  84. uniform sampler2D _DetailMask;
  85. uniform float4 _DetailMask_ST;
  86. uniform float _SnowNormalCoverHardness;
  87. uniform sampler2D _SnowNormalRGB;
  88. uniform float _SnowTiling;
  89. uniform float _TriplanarCoverFalloff;
  90. uniform float _SnowNormalScale;
  91. uniform float _Snow_Amount;
  92. uniform float _Snow_AmountGrowSpeed;
  93. uniform float _SnowMaxAngle;
  94. uniform float _SnowHardness;
  95. uniform float _Snow_Min_Height;
  96. uniform float _Snow_Min_Height_Blending;
  97. uniform sampler2D _SnowMaskB;
  98. uniform float4 _SnowMaskB_ST;
  99. uniform float _SnowMaskPower;
  100. uniform sampler2D _SnowHeightG;
  101. uniform float _SnowHeightSharpness;
  102. uniform float4 _Color;
  103. uniform float _DetailAlbedoPower;
  104. uniform sampler2D _SnowAlbedoRGB;
  105. uniform float4 _SnowAlbedoColor;
  106. uniform sampler2D _SpecularRGBSmoothnesA;
  107. uniform float _SpecularPower;
  108. uniform sampler2D _Snow_SpecularRGBSmoothnessA;
  109. uniform float _SnowSpecularPower;
  110. uniform float _SmoothnessPower;
  111. uniform float _SnowSmoothnessPower;
  112. uniform sampler2D _AmbientOcclusionG;
  113. uniform float _AmbientOcclusionPower;
  114. uniform sampler2D _SnowAmbientOcclusionG;
  115. uniform float _SnowAmbientOcclusionPower;
  116. inline float3 TriplanarSamplingSNF( sampler2D topTexMap, float3 worldPos, float3 worldNormal, float falloff, float tilling, float3 normalScale, float3 index )
  117. {
  118. float3 projNormal = ( pow( abs( worldNormal ), falloff ) );
  119. projNormal /= projNormal.x + projNormal.y + projNormal.z;
  120. float3 nsign = sign( worldNormal );
  121. half4 xNorm; half4 yNorm; half4 zNorm;
  122. xNorm = ( tex2D( topTexMap, tilling * worldPos.zy * float2( nsign.x, 1.0 ) ) );
  123. yNorm = ( tex2D( topTexMap, tilling * worldPos.xz * float2( nsign.y, 1.0 ) ) );
  124. zNorm = ( tex2D( topTexMap, tilling * worldPos.xy * float2( -nsign.z, 1.0 ) ) );
  125. xNorm.xyz = half3( UnpackScaleNormal( xNorm, normalScale.y ).xy * float2( nsign.x, 1.0 ) + worldNormal.zy, worldNormal.x ).zyx;
  126. yNorm.xyz = half3( UnpackScaleNormal( yNorm, normalScale.x ).xy * float2( nsign.y, 1.0 ) + worldNormal.xz, worldNormal.y ).xzy;
  127. zNorm.xyz = half3( UnpackScaleNormal( zNorm, normalScale.y ).xy * float2( -nsign.z, 1.0 ) + worldNormal.xy, worldNormal.z ).xyz;
  128. return normalize( xNorm.xyz * projNormal.x + yNorm.xyz * projNormal.y + zNorm.xyz * projNormal.z );
  129. }
  130. inline float4 TriplanarSamplingSF( sampler2D topTexMap, float3 worldPos, float3 worldNormal, float falloff, float tilling, float3 normalScale, float3 index )
  131. {
  132. float3 projNormal = ( pow( abs( worldNormal ), falloff ) );
  133. projNormal /= projNormal.x + projNormal.y + projNormal.z;
  134. float3 nsign = sign( worldNormal );
  135. half4 xNorm; half4 yNorm; half4 zNorm;
  136. xNorm = ( tex2D( topTexMap, tilling * worldPos.zy * float2( nsign.x, 1.0 ) ) );
  137. yNorm = ( tex2D( topTexMap, tilling * worldPos.xz * float2( nsign.y, 1.0 ) ) );
  138. zNorm = ( tex2D( topTexMap, tilling * worldPos.xy * float2( -nsign.z, 1.0 ) ) );
  139. return xNorm * projNormal.x + yNorm * projNormal.y + zNorm * projNormal.z;
  140. }
  141. void surf( Input i , inout SurfaceOutputStandardSpecular o )
  142. {
  143. float2 uv_MainTex = i.uv_texcoord * _MainTex_ST.xy + _MainTex_ST.zw;
  144. float3 tex2DNode4 = UnpackScaleNormal( tex2D( _BumpMap, uv_MainTex ), _BumpScale );
  145. float2 uv_DetailAlbedoMap = i.uv_texcoord * _DetailAlbedoMap_ST.xy + _DetailAlbedoMap_ST.zw;
  146. float3 tex2DNode206 = UnpackScaleNormal( tex2D( _DetailNormalMap, uv_DetailAlbedoMap ), _DetailNormalMapScale );
  147. float3 normalizeResult202 = normalize( BlendNormals( tex2DNode4 , tex2DNode206 ) );
  148. float2 uv_DetailMask = i.uv_texcoord * _DetailMask_ST.xy + _DetailMask_ST.zw;
  149. float4 tex2DNode195 = tex2D( _DetailMask, uv_DetailMask );
  150. float3 lerpResult193 = lerp( tex2DNode4 , normalizeResult202 , tex2DNode195.a);
  151. float3 normalizeResult201 = normalize( BlendNormals( UnpackScaleNormal( tex2D( _BumpMap, uv_MainTex ), _SnowNormalCoverHardness ) , tex2DNode206 ) );
  152. float temp_output_122_0 = ( 1.0 / _SnowTiling );
  153. float3 ase_worldPos = i.worldPos;
  154. float3 ase_worldNormal = WorldNormalVector( i, float3( 0, 0, 1 ) );
  155. float3 ase_worldTangent = WorldNormalVector( i, float3( 1, 0, 0 ) );
  156. float3 ase_worldBitangent = WorldNormalVector( i, float3( 0, 1, 0 ) );
  157. float3x3 ase_worldToTangent = float3x3( ase_worldTangent, ase_worldBitangent, ase_worldNormal );
  158. float3 triplanar166 = TriplanarSamplingSNF( _SnowNormalRGB, ase_worldPos, ase_worldNormal, _TriplanarCoverFalloff, temp_output_122_0, _SnowNormalScale, 0 );
  159. float3 tanTriplanarNormal166 = mul( ase_worldToTangent, triplanar166 );
  160. float temp_output_225_0 = ( 4.0 - _Snow_AmountGrowSpeed );
  161. float clampResult224 = clamp( pow( ( _Snow_Amount / temp_output_225_0 ) , temp_output_225_0 ) , 0.0 , 2.0 );
  162. float clampResult89 = clamp( ase_worldNormal.y , 0.0 , 0.999999 );
  163. float temp_output_88_0 = ( _SnowMaxAngle / 45.0 );
  164. float clampResult98 = clamp( ( clampResult89 - ( 1.0 - temp_output_88_0 ) ) , 0.0 , 2.0 );
  165. float temp_output_83_0 = ( ( 1.0 - _Snow_Min_Height ) + ase_worldPos.y );
  166. float clampResult95 = clamp( ( temp_output_83_0 + 1.0 ) , 0.0 , 1.0 );
  167. float clampResult97 = clamp( ( ( 1.0 - ( ( temp_output_83_0 + _Snow_Min_Height_Blending ) / temp_output_83_0 ) ) + -0.5 ) , 0.0 , 1.0 );
  168. float clampResult103 = clamp( ( clampResult95 + clampResult97 ) , 0.0 , 1.0 );
  169. float temp_output_106_0 = ( pow( ( clampResult98 * ( 1.0 / temp_output_88_0 ) ) , _SnowHardness ) * clampResult103 );
  170. float3 lerpResult115 = lerp( normalizeResult201 , tanTriplanarNormal166 , ( saturate( ( ase_worldNormal.y * clampResult224 ) ) * temp_output_106_0 ));
  171. float2 uv_SnowMaskB = i.uv_texcoord * _SnowMaskB_ST.xy + _SnowMaskB_ST.zw;
  172. float clampResult236 = clamp( ( tex2D( _SnowMaskB, uv_SnowMaskB ).b * _SnowMaskPower ) , 0.0 , 1.0 );
  173. float4 triplanar175 = TriplanarSamplingSF( _SnowHeightG, ase_worldPos, ase_worldNormal, _TriplanarCoverFalloff, temp_output_122_0, 1.0, 0 );
  174. #ifdef _USEDYNAMICSNOWTSTATICMASKF_ON
  175. float staticSwitch226 = ( clampResult236 * ( saturate( ( ( ( (WorldNormalVector( i , lerpResult115 )).y * clampResult224 ) * ( ( clampResult224 * _SnowHardness ) * temp_output_106_0 ) ) * pow( triplanar175.y , _SnowHeightSharpness ) ) ) * 1.0 ) );
  176. #else
  177. float staticSwitch226 = clampResult236;
  178. #endif
  179. #ifdef _USESNOW_ON
  180. float staticSwitch229 = staticSwitch226;
  181. #else
  182. float staticSwitch229 = 1E-05;
  183. #endif
  184. float SnowCover231 = staticSwitch229;
  185. float3 lerpResult177 = lerp( lerpResult193 , lerpResult115 , SnowCover231);
  186. o.Normal = lerpResult177;
  187. float4 temp_output_44_0 = ( tex2D( _MainTex, uv_MainTex ) * _Color );
  188. float4 blendOpSrc189 = temp_output_44_0;
  189. float4 blendOpDest189 = ( _DetailAlbedoPower * tex2D( _DetailAlbedoMap, uv_DetailAlbedoMap ) );
  190. float4 lerpResult192 = lerp( temp_output_44_0 , (( blendOpDest189 > 0.5 ) ? ( 1.0 - ( 1.0 - 2.0 * ( blendOpDest189 - 0.5 ) ) * ( 1.0 - blendOpSrc189 ) ) : ( 2.0 * blendOpDest189 * blendOpSrc189 ) ) , ( _DetailAlbedoPower * tex2DNode195.a ));
  191. float4 triplanar162 = TriplanarSamplingSF( _SnowAlbedoRGB, ase_worldPos, ase_worldNormal, _TriplanarCoverFalloff, temp_output_122_0, 1.0, 0 );
  192. float4 lerpResult10 = lerp( lerpResult192 , ( triplanar162 * _SnowAlbedoColor ) , SnowCover231);
  193. o.Albedo = lerpResult10.xyz;
  194. float4 tex2DNode29 = tex2D( _SpecularRGBSmoothnesA, uv_MainTex );
  195. float4 triplanar165 = TriplanarSamplingSF( _Snow_SpecularRGBSmoothnessA, ase_worldPos, ase_worldNormal, _TriplanarCoverFalloff, temp_output_122_0, 1.0, 0 );
  196. float4 break150 = triplanar165;
  197. float3 appendResult151 = (float3(break150.x , break150.y , break150.z));
  198. float4 lerpResult17 = lerp( ( tex2DNode29 * _SpecularPower ) , float4( ( appendResult151 * _SnowSpecularPower ) , 0.0 ) , SnowCover231);
  199. o.Specular = lerpResult17.rgb;
  200. float lerpResult28 = lerp( ( tex2DNode29.a * _SmoothnessPower ) , ( break150.w * _SnowSmoothnessPower ) , SnowCover231);
  201. o.Smoothness = lerpResult28;
  202. float clampResult67 = clamp( tex2D( _AmbientOcclusionG, uv_MainTex ).g , ( 1.0 - _AmbientOcclusionPower ) , 1.0 );
  203. float4 triplanar170 = TriplanarSamplingSF( _SnowAmbientOcclusionG, ase_worldPos, ase_worldNormal, _TriplanarCoverFalloff, temp_output_122_0, 1.0, 0 );
  204. float clampResult69 = clamp( triplanar170.y , ( 1.0 - _SnowAmbientOcclusionPower ) , 1.0 );
  205. float lerpResult27 = lerp( clampResult67 , clampResult69 , SnowCover231);
  206. o.Occlusion = lerpResult27;
  207. o.Alpha = 1;
  208. }
  209. ENDCG
  210. CGPROGRAM
  211. #pragma surface surf StandardSpecular keepalpha fullforwardshadows
  212. ENDCG
  213. Pass
  214. {
  215. Name "ShadowCaster"
  216. Tags{ "LightMode" = "ShadowCaster" }
  217. ZWrite On
  218. CGPROGRAM
  219. #pragma vertex vert
  220. #pragma fragment frag
  221. #pragma target 3.0
  222. #pragma multi_compile_shadowcaster
  223. #pragma multi_compile UNITY_PASS_SHADOWCASTER
  224. #pragma skip_variants FOG_LINEAR FOG_EXP FOG_EXP2
  225. #include "HLSLSupport.cginc"
  226. #if ( SHADER_API_D3D11 || SHADER_API_GLCORE || SHADER_API_GLES3 || SHADER_API_METAL || SHADER_API_VULKAN )
  227. #define CAN_SKIP_VPOS
  228. #endif
  229. #include "UnityCG.cginc"
  230. #include "Lighting.cginc"
  231. #include "UnityPBSLighting.cginc"
  232. struct v2f
  233. {
  234. V2F_SHADOW_CASTER;
  235. float2 customPack1 : TEXCOORD1;
  236. float4 tSpace0 : TEXCOORD2;
  237. float4 tSpace1 : TEXCOORD3;
  238. float4 tSpace2 : TEXCOORD4;
  239. UNITY_VERTEX_INPUT_INSTANCE_ID
  240. };
  241. v2f vert( appdata_full v )
  242. {
  243. v2f o;
  244. UNITY_SETUP_INSTANCE_ID( v );
  245. UNITY_INITIALIZE_OUTPUT( v2f, o );
  246. UNITY_TRANSFER_INSTANCE_ID( v, o );
  247. Input customInputData;
  248. float3 worldPos = mul( unity_ObjectToWorld, v.vertex ).xyz;
  249. half3 worldNormal = UnityObjectToWorldNormal( v.normal );
  250. half3 worldTangent = UnityObjectToWorldDir( v.tangent.xyz );
  251. half tangentSign = v.tangent.w * unity_WorldTransformParams.w;
  252. half3 worldBinormal = cross( worldNormal, worldTangent ) * tangentSign;
  253. o.tSpace0 = float4( worldTangent.x, worldBinormal.x, worldNormal.x, worldPos.x );
  254. o.tSpace1 = float4( worldTangent.y, worldBinormal.y, worldNormal.y, worldPos.y );
  255. o.tSpace2 = float4( worldTangent.z, worldBinormal.z, worldNormal.z, worldPos.z );
  256. o.customPack1.xy = customInputData.uv_texcoord;
  257. o.customPack1.xy = v.texcoord;
  258. TRANSFER_SHADOW_CASTER_NORMALOFFSET( o )
  259. return o;
  260. }
  261. half4 frag( v2f IN
  262. #if !defined( CAN_SKIP_VPOS )
  263. , UNITY_VPOS_TYPE vpos : VPOS
  264. #endif
  265. ) : SV_Target
  266. {
  267. UNITY_SETUP_INSTANCE_ID( IN );
  268. Input surfIN;
  269. UNITY_INITIALIZE_OUTPUT( Input, surfIN );
  270. surfIN.uv_texcoord = IN.customPack1.xy;
  271. float3 worldPos = float3( IN.tSpace0.w, IN.tSpace1.w, IN.tSpace2.w );
  272. half3 worldViewDir = normalize( UnityWorldSpaceViewDir( worldPos ) );
  273. surfIN.worldPos = worldPos;
  274. surfIN.worldNormal = float3( IN.tSpace0.z, IN.tSpace1.z, IN.tSpace2.z );
  275. surfIN.internalSurfaceTtoW0 = IN.tSpace0.xyz;
  276. surfIN.internalSurfaceTtoW1 = IN.tSpace1.xyz;
  277. surfIN.internalSurfaceTtoW2 = IN.tSpace2.xyz;
  278. SurfaceOutputStandardSpecular o;
  279. UNITY_INITIALIZE_OUTPUT( SurfaceOutputStandardSpecular, o )
  280. surf( surfIN, o );
  281. #if defined( CAN_SKIP_VPOS )
  282. float2 vpos = IN.pos;
  283. #endif
  284. SHADOW_CASTER_FRAGMENT( IN )
  285. }
  286. ENDCG
  287. }
  288. }
  289. Fallback "Diffuse"
  290. }