1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-23 21:23:53 +00:00
openmw/files/shaders/lib/water/ripples.glsl

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

30 lines
894 B
Text
Raw Normal View History

2023-02-25 19:03:39 +00:00
#ifndef LIB_WATER_RIPPLES
#define LIB_WATER_RIPPLES
float getTemporalWaveSizeMultiplier(in float time)
2023-02-25 19:03:39 +00:00
{
return 1.0 + 0.055 * sin(16.0 * time) + 0.065 * sin(12.87645 * time);
2023-02-25 19:03:39 +00:00
}
vec4 applySprings(in vec4 samplerData, in vec4 n, in vec4 n2)
2023-02-25 19:03:39 +00:00
{
vec4 storage = vec4(0.0, samplerData.r, 0.0, 0.0);
2023-02-25 19:03:39 +00:00
// Tweak to look most like water, not a physically accurate simulation
const float a = 0.14;
const float udamp = 0.02;
const float vdamp = 0.02;
2023-02-25 19:03:39 +00:00
// Apply 2d wave equation with dampening
// Continous impulse needed to maintain simulation, otherwise ripples will fade
float nsum = n.x + n.y + n.z + n.w;
storage.r = a * nsum + ((2.0 - udamp - vdamp) - 4.0 * a) * samplerData.r - (1.0 - vdamp) * samplerData.g;
2023-02-25 19:03:39 +00:00
// Calculate normal and store in blue-alpha channel
storage.ba = 2.0 * (n.xy - n.zw) + 0.5 * (n2.xy - n2.zw);
2023-02-25 19:03:39 +00:00
return storage;
2023-02-25 19:03:39 +00:00
}
#endif