VegetationShadow.hlsl 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #include "Uniforms.hlsl"
  2. #include "Samplers.hlsl"
  3. #include "Transform.hlsl"
  4. #ifndef D3D11
  5. // D3D9 uniforms
  6. uniform float cWindHeightFactor;
  7. uniform float cWindHeightPivot;
  8. uniform float cWindPeriod;
  9. uniform float2 cWindWorldSpacing;
  10. #ifdef WINDSTEMAXIS
  11. uniform float3 cWindStemAxis;
  12. #endif
  13. #else
  14. // D3D11 constant buffer
  15. cbuffer CustomVS : register(b6)
  16. {
  17. float cWindHeightFactor;
  18. float cWindHeightPivot;
  19. float cWindPeriod;
  20. float2 cWindWorldSpacing;
  21. #ifdef WINDSTEMAXIS
  22. float3 cWindStemAxis;
  23. #endif
  24. }
  25. #endif
  26. void VS(float4 iPos : POSITION,
  27. #ifdef SKINNED
  28. float4 iBlendWeights : BLENDWEIGHT,
  29. int4 iBlendIndices : BLENDINDICES,
  30. #endif
  31. #ifdef INSTANCED
  32. float4x3 iModelInstance : TEXCOORD4,
  33. #endif
  34. float2 iTexCoord : TEXCOORD0,
  35. #ifdef VSM_SHADOW
  36. out float4 oTexCoord : TEXCOORD0,
  37. #else
  38. out float2 oTexCoord : TEXCOORD0,
  39. #endif
  40. out float4 oPos : OUTPOSITION)
  41. {
  42. float4x3 modelMatrix = iModelMatrix;
  43. float3 worldPos = GetWorldPos(modelMatrix);
  44. #ifdef WINDSTEMAXIS
  45. float stemDistance = dot(iPos, cWindStemAxis);
  46. #else
  47. float stemDistance = iPos.y;
  48. #endif
  49. float windStrength = max(stemDistance - cWindHeightPivot, 0.0) * cWindHeightFactor;
  50. float windPeriod = cElapsedTime * cWindPeriod + dot(worldPos.xz, cWindWorldSpacing);
  51. worldPos.x += windStrength * sin(windPeriod);
  52. worldPos.z -= windStrength * cos(windPeriod);
  53. oPos = GetClipPos(worldPos);
  54. #ifdef VSM_SHADOW
  55. oTexCoord = float4(GetTexCoord(iTexCoord), oPos.z, oPos.w);
  56. #else
  57. oTexCoord = GetTexCoord(iTexCoord);
  58. #endif
  59. }