veloren/assets/voxygen/shaders/lod-object-vert.glsl

57 lines
1.6 KiB
Plaintext
Raw Normal View History

2022-05-08 23:53:19 +00:00
#version 420 core
#include <constants.glsl>
#define LIGHTING_TYPE LIGHTING_TYPE_REFLECTION
#define LIGHTING_REFLECTION_KIND LIGHTING_REFLECTION_KIND_GLOSSY
#define LIGHTING_TRANSPORT_MODE LIGHTING_TRANSPORT_MODE_IMPORTANCE
#define LIGHTING_DISTRIBUTION_SCHEME LIGHTING_DISTRIBUTION_SCHEME_MICROFACET
#define LIGHTING_DISTRIBUTION LIGHTING_DISTRIBUTION_BECKMANN
#include <globals.glsl>
#include <srgb.glsl>
#include <random.glsl>
#include <lod.glsl>
layout(location = 0) in vec3 v_pos;
layout(location = 1) in vec3 v_norm;
layout(location = 2) in vec3 v_col;
layout(location = 3) in vec3 inst_pos;
2022-05-10 18:19:46 +00:00
layout(location = 4) in uvec3 inst_col;
layout(location = 5) in uint inst_flags;
2022-05-09 09:28:32 +00:00
2022-05-08 23:53:19 +00:00
layout(location = 0) out vec3 f_pos;
layout(location = 1) out vec3 f_norm;
layout(location = 2) out vec4 f_col;
2022-05-09 14:53:24 +00:00
layout(location = 3) out vec3 model_pos;
2023-04-07 13:03:03 +00:00
layout(location = 4) flat out uint f_flags;
2022-05-08 23:53:19 +00:00
void main() {
2022-05-11 14:00:44 +00:00
vec3 obj_pos = inst_pos - focus_off.xyz;
f_pos = obj_pos + v_pos;
2022-05-09 14:53:24 +00:00
model_pos = v_pos;
2022-05-08 23:53:19 +00:00
2022-05-11 14:00:44 +00:00
float pull_down = 1.0 / pow(distance(focus_pos.xy, obj_pos.xy) / (view_distance.x * 0.95), 150.0);
#ifndef EXPERIMENTAL_NOTERRAINPOP
f_pos.z -= pull_down;
#else
f_pos.z -= step(0.1, pull_down) * 10000.0;
#endif
2022-05-08 23:53:19 +00:00
2022-05-09 16:43:25 +00:00
#ifdef EXPERIMENTAL_CURVEDWORLD
f_pos.z -= pow(distance(f_pos.xy + focus_off.xy, focus_pos.xy + focus_off.xy) * 0.05, 2);
#endif
2022-05-10 18:19:46 +00:00
f_norm = v_norm;
2022-05-10 23:15:05 +00:00
f_col = vec4(vec3(inst_col) * (1.0 / 255.0) * v_col * (hash(inst_pos.xyxy) * 0.35 + 0.65), 1.0);
2023-04-07 13:03:03 +00:00
f_flags = inst_flags;
2022-05-09 09:28:32 +00:00
2022-05-08 23:53:19 +00:00
gl_Position =
all_mat *
vec4(f_pos, 1);
}