Tree_Leaves_Specular.shader 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. Shader "NatureManufacture Shaders/Trees/Tree_Leaves_Specular"
  2. {
  3. Properties
  4. {
  5. _Cutoff( "Mask Clip Value", Float ) = 0.57
  6. _MainTex("MainTex", 2D) = "white" {}
  7. _HealthyColor("Healthy Color", Color) = (1,0.9735294,0.9338235,1)
  8. _DryColor("Dry Color", Color) = (0.8676471,0.818369,0.6124567,1)
  9. _ColorNoiseSpread("Color Noise Spread", Float) = 50
  10. [NoScaleOffset]_BumpMap("BumpMap", 2D) = "bump" {}
  11. _BumpScale("BumpScale", Range( 0 , 3)) = 1
  12. _SpecularPower("Specular Power", Range( 0 , 2)) = 0
  13. [NoScaleOffset]_AmbientOcclusionGSmoothnessA("Ambient Occlusion (G) Smoothness (A)", 2D) = "white" {}
  14. _AmbientOcclusionPower("Ambient Occlusion Power", Range( 0 , 1)) = 1
  15. _SmoothnessPower("Smoothness Power", Range( 0 , 2)) = 0
  16. _InitialBend("Wind Initial Bend", Float) = 1
  17. _Stiffness("Wind Stiffness", Float) = 1
  18. _Drag("Wind Drag", Float) = 1
  19. _ShiverDrag("Wind Shiver Drag", Float) = 0.05
  20. _WindNormalInfluence("Wind Normal Influence", Float) = 0
  21. _ShiverDirectionality("Wind Shiver Directionality", Range( 0 , 1)) = 0.5
  22. [HideInInspector] _texcoord( "", 2D ) = "white" {}
  23. [HideInInspector] __dirty( "", Int ) = 1
  24. }
  25. SubShader
  26. {
  27. Tags{ "RenderType" = "TreeTransparentCutout" "Queue" = "AlphaTest+0" }
  28. Cull Off
  29. CGPROGRAM
  30. #include "UnityStandardUtils.cginc"
  31. #pragma target 3.0
  32. #pragma multi_compile_instancing
  33. #include "NMWind.cginc"
  34. #include "NM_indirect.cginc"
  35. #pragma vertex vert
  36. #pragma instancing_options procedural:setup
  37. #pragma multi_compile GPU_FRUSTUM_ON __
  38. #pragma surface surf StandardSpecular keepalpha addshadow fullforwardshadows dithercrossfade
  39. struct Input
  40. {
  41. float2 uv_texcoord;
  42. float3 worldPos;
  43. };
  44. uniform float _BumpScale;
  45. uniform sampler2D _BumpMap;
  46. uniform sampler2D _MainTex;
  47. uniform float4 _DryColor;
  48. uniform float4 _HealthyColor;
  49. uniform float _ColorNoiseSpread;
  50. uniform float _SpecularPower;
  51. uniform sampler2D _AmbientOcclusionGSmoothnessA;
  52. uniform float _SmoothnessPower;
  53. uniform float _AmbientOcclusionPower;
  54. uniform float _Cutoff = 0.57;
  55. float3 mod2D289( float3 x ) { return x - floor( x * ( 1.0 / 289.0 ) ) * 289.0; }
  56. float2 mod2D289( float2 x ) { return x - floor( x * ( 1.0 / 289.0 ) ) * 289.0; }
  57. float3 permute( float3 x ) { return mod2D289( ( ( x * 34.0 ) + 1.0 ) * x ); }
  58. float snoise( float2 v )
  59. {
  60. const float4 C = float4( 0.211324865405187, 0.366025403784439, -0.577350269189626, 0.024390243902439 );
  61. float2 i = floor( v + dot( v, C.yy ) );
  62. float2 x0 = v - i + dot( i, C.xx );
  63. float2 i1;
  64. i1 = ( x0.x > x0.y ) ? float2( 1.0, 0.0 ) : float2( 0.0, 1.0 );
  65. float4 x12 = x0.xyxy + C.xxzz;
  66. x12.xy -= i1;
  67. i = mod2D289( i );
  68. float3 p = permute( permute( i.y + float3( 0.0, i1.y, 1.0 ) ) + i.x + float3( 0.0, i1.x, 1.0 ) );
  69. float3 m = max( 0.5 - float3( dot( x0, x0 ), dot( x12.xy, x12.xy ), dot( x12.zw, x12.zw ) ), 0.0 );
  70. m = m * m;
  71. m = m * m;
  72. float3 x = 2.0 * frac( p * C.www ) - 1.0;
  73. float3 h = abs( x ) - 0.5;
  74. float3 ox = floor( x + 0.5 );
  75. float3 a0 = x - ox;
  76. m *= 1.79284291400159 - 0.85373472095314 * ( a0 * a0 + h * h );
  77. float3 g;
  78. g.x = a0.x * x0.x + h.x * x0.y;
  79. g.yz = a0.yz * x12.xz + h.yz * x12.yw;
  80. return 130.0 * dot( m, g );
  81. }
  82. void surf( Input i , inout SurfaceOutputStandardSpecular o )
  83. {
  84. float3 tex2DNode4 = UnpackScaleNormal( tex2D( _BumpMap, i.uv_texcoord ), _BumpScale );
  85. o.Normal = tex2DNode4;
  86. float4 tex2DNode3 = tex2D( _MainTex, i.uv_texcoord );
  87. float3 ase_worldPos = i.worldPos;
  88. float2 appendResult357 = (float2(ase_worldPos.x , ase_worldPos.z));
  89. float simplePerlin2D347 = snoise( ( appendResult357 / _ColorNoiseSpread ) );
  90. float4 lerpResult363 = lerp( _DryColor , _HealthyColor , simplePerlin2D347);
  91. float4 temp_output_35_0 = ( tex2DNode3 * lerpResult363 );
  92. o.Albedo = temp_output_35_0.rgb;
  93. o.Specular = ( temp_output_35_0 * _SpecularPower ).rgb;
  94. float4 tex2DNode37 = tex2D( _AmbientOcclusionGSmoothnessA, i.uv_texcoord );
  95. o.Smoothness = ( tex2DNode37.a * _SmoothnessPower );
  96. float clampResult41 = clamp( tex2DNode37.g , ( 1.0 - _AmbientOcclusionPower ) , 1.0 );
  97. o.Occlusion = clampResult41;
  98. o.Alpha = 1;
  99. clip( tex2DNode3.a - _Cutoff );
  100. }
  101. ENDCG
  102. }
  103. Fallback "Diffuse"
  104. }