~plainCterraindatashaders
42 itemsDownload ./*

..
frag_shader_clouds.glsl
frag_shader_cube.glsl
frag_shader_depth.glsl
frag_shader_fire.glsl
frag_shader_fireball.glsl
frag_shader_lava.glsl
frag_shader_line.glsl
frag_shader_main.glsl
frag_shader_moon.glsl
frag_shader_post.glsl
frag_shader_sky.glsl
frag_shader_stencil.glsl
frag_shader_sun.glsl
frag_shader_t3d.glsl
frag_shader_terrain.glsl
frag_shader_text.glsl
frag_shader_ui.glsl
frag_shader_vortex.glsl
frag_shader_water2.glsl
frag_shader_water_depth.glsl
frag_shader_water_height.glsl
vert_shader_clouds.glsl
vert_shader_cube.glsl
vert_shader_depth.glsl
vert_shader_fire.glsl
vert_shader_fireball.glsl
vert_shader_lava.glsl
vert_shader_line.glsl
vert_shader_main.glsl
vert_shader_moon.glsl
vert_shader_post.glsl
vert_shader_sky.glsl
vert_shader_stencil.glsl
vert_shader_sun.glsl
vert_shader_t3d.glsl
vert_shader_terrain.glsl
vert_shader_text.glsl
vert_shader_ui.glsl
vert_shader_vortex.glsl
vert_shader_water2.glsl
vert_shader_water_depth.glsl
vert_shader_water_height.glsl


shadersvert_shader_water_depth.glsl
3 KB• 10•  1 month ago•  DownloadRawClose
1 month ago•  10

{}
#version 330 core
layout (location = 0) in vec3 vPos;
layout (location = 1) in vec2 vTexCoord;
invariant gl_Position;

uniform mat4 MVP;
uniform vec3 data; // time offset scale

//out vec2 TexCoord;
//out float time;
out float depth;

out vec3 FragPos;

// Simple 2D noise function
float noise3(vec2 p) {
    // A basic pseudo-random function (not true Perlin noise, but sufficient for perturbation)
    return fract(sin(dot(p, vec2(12.9898, 78.233))) * 43758.5453);
}

// Smooth noise by interpolation (optional enhancement)
float smoothNoise(vec2 p) {
    vec2 i = floor(p);
    vec2 f = fract(p);
    vec2 u = f * f * (3.0 - 2.0 * f); // Smoothstep
    float a = noise3(i);
    float b = noise3(i + vec2(1.0, 0.0));
    float c = noise3(i + vec2(0.0, 1.0));
    float d = noise3(i + vec2(1.0, 1.0));
    return mix(mix(a, b, u.x), mix(c, d, u.x), u.y);
}


void main() {
    vec2 TexCoord = vTexCoord;
    float height = 0.0;
    //vec3 pos = position;
    // Calculate relative position to origin
    float wlev=data.y-1.1;

    float time=data.x;
    float scale=22.8;
    vec3 sPos = vPos; // scale
    TexCoord = vec2(vTexCoord.x, vTexCoord.y) * scale;
    TexCoord -= scale/2;
    vec2 vertexPosition = TexCoord * (scale + sin(TexCoord.x * 1.0) * 0.5);
    sPos = vec3(0.0, wlev, 0.0);
    sPos.x = vertexPosition.x;
    sPos.z = vertexPosition.y; // Assuming z is your second axis
    //sPos.y += sin(TexCoord.x * 50.0 + time) * 0.2; // Example height with animation



    // Wave parameters: directions, frequencies, speeds, amplitudes
    vec2 dirs[4] = vec2[](
        vec2(1.0, 0.0),              // Horizontal waves
        vec2(0.0, 1.0),              // Vertical waves
        normalize(vec2(1.0, 1.0)),   // Diagonal waves (45°)
        normalize(vec2(-1.0, 1.0))   // Diagonal waves (135°)
    );
    float freqs[4] = float[](2.0, 2.0, 3.0, 3.0);    // Frequencies (waves per unit)
    float speeds[4] = float[](1.0, 1.2, 1.5, 1.3);   // Speeds (phase shift per second)
    float amps[4] = float[](0.2, 0.2, 0.1, 0.1);     // Amplitudes (wave height)

    // Compute base wave height with cross waves
    height = 0.0;
    for (int i = 0; i < 4; i++) {
        float phase = dot(dirs[i], TexCoord) * freqs[i] + time * speeds[i];
        height += amps[i] * sin(phase);
    }

   // Add noise to perturb the UV coordinates for irregularity
    float noiseValue = smoothNoise(TexCoord + vec2(time * 0.1, time * 0.05));
    vec2 uvPerturbed = TexCoord + vec2(noiseValue * 0.1, noiseValue * 0.1);

    // Recompute height with perturbed UVs for more natural waves
    height = 0.0;
    for (int i = 0; i < 4; i++) {
        float phase = dot(dirs[i], uvPerturbed) * freqs[i] + time * speeds[i];
        height += amps[i] * sin(phase);
    }

    // Optional: Add small-scale noise directly to height
    height += 0.05 * smoothNoise(TexCoord * 5.0 + vec2(time * 0.2));

    // Displace the vertex along the y-axis (assuming y-up)
    sPos.y += height;

    gl_Position = MVP * vec4(sPos.x, sPos.y, sPos.z, 1.0);
    FragPos = vec3(MVP * vec4(sPos.x, sPos.y, sPos.z, 1.0));

    //depth = gl_Position.z / gl_Position.w; // Linearize if need
    depth = gl_Position.z;
    //depth = ((gl_DepthRange.diff * (gl_Position.z / glPosition.w)) + gl_DepthRange.near + gl_DepthRange.far) / 2.0;
}

Top
©twily.info 2013 - 2025
twily at twily dot info



2 272 896 visits
... ^ v