2012-05-09 15:30:53 +00:00
|
|
|
!!permu FOG
|
2015-03-03 00:14:43 +00:00
|
|
|
!!cvarf r_wateralpha
|
|
|
|
|
|
|
|
#include "sys/defs.h"
|
2012-05-09 15:30:53 +00:00
|
|
|
|
|
|
|
//this is the shader that's responsible for drawing default q1 turbulant water surfaces
|
|
|
|
//this is expected to be moderately fast.
|
|
|
|
|
|
|
|
#include "sys/fog.h"
|
|
|
|
varying vec2 tc;
|
|
|
|
#ifdef VERTEX_SHADER
|
|
|
|
void main ()
|
|
|
|
{
|
|
|
|
tc = v_texcoord.st;
|
2015-03-03 00:14:43 +00:00
|
|
|
#ifdef FLOW
|
|
|
|
tc.s += e_time * -0.5;
|
|
|
|
#endif
|
2012-05-09 15:30:53 +00:00
|
|
|
gl_Position = ftetransform();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#ifdef FRAGMENT_SHADER
|
2013-03-12 23:13:39 +00:00
|
|
|
#ifndef ALPHA
|
2012-05-09 15:30:53 +00:00
|
|
|
uniform float cvar_r_wateralpha;
|
2013-03-12 23:13:39 +00:00
|
|
|
#define USEALPHA cvar_r_wateralpha
|
|
|
|
#else
|
|
|
|
#define USEALPHA float(ALPHA)
|
|
|
|
#endif
|
2012-05-09 15:30:53 +00:00
|
|
|
void main ()
|
|
|
|
{
|
|
|
|
vec2 ntc;
|
|
|
|
ntc.s = tc.s + sin(tc.t+e_time)*0.125;
|
|
|
|
ntc.t = tc.t + sin(tc.s+e_time)*0.125;
|
2015-03-03 00:14:43 +00:00
|
|
|
vec3 ts = vec3(texture2D(s_diffuse, ntc));
|
2013-03-12 23:13:39 +00:00
|
|
|
gl_FragColor = fog4(vec4(ts, USEALPHA));
|
2012-05-09 15:30:53 +00:00
|
|
|
}
|
|
|
|
#endif
|