Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: data/branches/Shader_HS18/programs/GLSL120/Ocean2GLSL.vert @ 12397

Last change on this file since 12397 was 12115, checked in by wiesep, 6 years ago

Changed folder structure, deletet some unused files and cleaned up code

File size: 2.9 KB
Line 
1/*********************************************************************NVMH3****
2Copyright NVIDIA Corporation 2003
3TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW, THIS SOFTWARE IS PROVIDED
4*AS IS* AND NVIDIA AND ITS SUPPLIERS DISCLAIM ALL WARRANTIES, EITHER EXPRESS
5OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY
6AND FITNESS FOR A PARTICULAR PURPOSE.  IN NO EVENT SHALL NVIDIA OR ITS SUPPLIERS
7BE LIABLE FOR ANY SPECIAL, INCIDENTAL, INDIRECT, OR CONSEQUENTIAL DAMAGES
8WHATSOEVER (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS,
9BUSINESS INTERRUPTION, LOSS OF BUSINESS INFORMATION, OR ANY OTHER PECUNIARY LOSS)
10ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN IF NVIDIA HAS
11BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
12
13
14Comments:
15        Simple ocean shader with animated bump map and geometric waves
16        Based partly on "Effective Water Simulation From Physical Models", GPU Gems
17
1811 Aug 05: converted from HLSL to GLSL by Jeff Doyle (nfz) to work in Ogre
19
20******************************************************************************/
21
22uniform vec3 eyePosition;
23uniform float BumpScale;
24uniform vec2 textureScale;
25uniform vec2 bumpSpeed;
26uniform float time;
27uniform float waveFreq;
28uniform float waveAmp;
29uniform mat4 worldViewProj;
30
31attribute vec4 vertex;
32attribute vec4 uv0;
33
34varying mat3 rotMatrix; //  transform from tangent to obj space
35varying vec2 bumpCoord0;
36varying vec2 bumpCoord1;
37varying vec2 bumpCoord2;
38varying vec3 eyeVector;
39
40// wave functions
41struct Wave {
42  float freq;  // 2*PI / wavelength
43  float amp;   // amplitude
44  float phase; // speed * 2*PI / wavelength
45  vec2 dir;
46};
47
48
49void main(void)
50{
51        #define NWAVES 2
52
53        Wave wave[NWAVES];
54
55        wave[0] = Wave( waveFreq, waveAmp, 0.5, vec2(-1, 0) );
56        wave[1] = Wave( 3.0 * waveFreq, 0.33 * waveAmp, 1.7, vec2(-0.7, 0.7) );
57
58    vec4 P = vertex;
59
60        // sum waves
61        float ddx = 0.0, ddy = 0.0;
62        float deriv;
63        float angle;
64
65        // wave synthesis using two sine waves at different frequencies and phase shift
66        for(int i = 0; i<NWAVES; ++i)
67        {
68                angle = dot(wave[i].dir, P.xz) * wave[i].freq + time * wave[i].phase;
69                P.y += wave[i].amp * sin( angle );
70                // calculate derivate of wave function
71                deriv = wave[i].freq * wave[i].amp * cos(angle);
72                ddx -= deriv * wave[i].dir.x;
73                ddy -= deriv * wave[i].dir.y;
74        }
75
76        // compute the 3x3 transform from tangent space to object space
77        // compute tangent basis
78    vec3 T = normalize(vec3(1.0, ddy, 0.0)) * BumpScale;
79    vec3 B = normalize(vec3(0.0, ddx, 1.0)) * BumpScale;
80    vec3 N = normalize(vec3(ddx, 1.0, ddy));
81
82        rotMatrix = mat3(T, B, N);
83
84        gl_Position = worldViewProj * P;
85
86        // calculate texture coordinates for normal map lookup
87        bumpCoord0.xy = uv0.xy * textureScale + time * bumpSpeed;
88        bumpCoord1.xy = uv0.xy * textureScale * 2.0 + time * bumpSpeed * 4.0;
89        bumpCoord2.xy = uv0.xy * textureScale * 4.0 + time * bumpSpeed * 8.0;
90
91        eyeVector = P.xyz - eyePosition; // eye position in vertex space
92}
Note: See TracBrowser for help on using the repository browser.