mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 05:26:39 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			29 lines
		
	
	
	
		
			894 B
		
	
	
	
		
			GLSL
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
	
		
			894 B
		
	
	
	
		
			GLSL
		
	
	
	
	
	
| #ifndef LIB_WATER_RIPPLES
 | |
| #define LIB_WATER_RIPPLES
 | |
| 
 | |
| float getTemporalWaveSizeMultiplier(in float time)
 | |
| {
 | |
|     return 1.0 + 0.055 * sin(16.0 * time) + 0.065 * sin(12.87645 * time);
 | |
| }
 | |
| 
 | |
| vec4 applySprings(in vec4 samplerData, in vec4 n, in vec4 n2)
 | |
| {
 | |
|     vec4 storage = vec4(0.0, samplerData.r, 0.0, 0.0);
 | |
| 
 | |
|     // Tweak to look most like water, not a physically accurate simulation
 | |
|     const float a = 0.28;
 | |
|     const float udamp = 0.04;
 | |
|     const float vdamp = 0.04;
 | |
| 
 | |
|     // 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;
 | |
| 
 | |
|     // Calculate normal and store in blue-alpha channel
 | |
|     storage.ba = 2.0 * (n.xz - n.yw) + 0.5 * (n2.xz - n2.yw);
 | |
| 
 | |
|     return storage;
 | |
| }
 | |
| 
 | |
| #endif
 |