2019-01-11 23:18:34 +00:00
|
|
|
#version 330 core
|
|
|
|
|
2019-05-12 09:10:13 +00:00
|
|
|
#include <globals.glsl>
|
2020-04-12 22:29:59 +00:00
|
|
|
#include <lod.glsl>
|
2019-05-12 09:10:13 +00:00
|
|
|
|
2020-04-25 14:07:58 +00:00
|
|
|
in uint v_pos_norm;
|
2019-01-14 14:18:58 +00:00
|
|
|
in vec3 v_norm;
|
2020-04-25 14:07:58 +00:00
|
|
|
in uint v_col;
|
|
|
|
in uint v_ao_bone;
|
2019-01-11 23:18:34 +00:00
|
|
|
|
|
|
|
layout (std140)
|
|
|
|
uniform u_locals {
|
|
|
|
mat4 model_mat;
|
2019-05-13 13:58:01 +00:00
|
|
|
vec4 model_col;
|
2020-04-04 19:36:55 +00:00
|
|
|
// bit 0 - is player
|
|
|
|
// bit 1-31 - unused
|
|
|
|
int flags;
|
2019-01-11 23:18:34 +00:00
|
|
|
};
|
|
|
|
|
2019-01-13 20:53:55 +00:00
|
|
|
struct BoneData {
|
|
|
|
mat4 bone_mat;
|
|
|
|
};
|
|
|
|
|
|
|
|
layout (std140)
|
|
|
|
uniform u_bones {
|
2020-04-25 14:38:17 +00:00
|
|
|
// Warning: might not actually be 16 elements long. Don't index out of bounds!
|
2019-01-13 20:53:55 +00:00
|
|
|
BoneData bones[16];
|
|
|
|
};
|
|
|
|
|
2019-01-11 23:18:34 +00:00
|
|
|
out vec3 f_pos;
|
2019-01-13 20:53:55 +00:00
|
|
|
out vec3 f_col;
|
2020-04-17 20:58:36 +00:00
|
|
|
out float f_ao;
|
2019-08-03 09:55:45 +00:00
|
|
|
flat out vec3 f_norm;
|
2020-04-25 20:23:57 +00:00
|
|
|
// out float f_alt;
|
|
|
|
// out vec4 f_shadow;
|
2019-01-11 23:18:34 +00:00
|
|
|
|
|
|
|
void main() {
|
2019-08-03 09:55:45 +00:00
|
|
|
// Pre-calculate bone matrix
|
2020-04-25 14:07:58 +00:00
|
|
|
uint bone_idx = (v_ao_bone >> 2) & 0x3Fu;
|
|
|
|
mat4 combined_mat = model_mat * bones[bone_idx].bone_mat;
|
|
|
|
|
|
|
|
vec3 pos = vec3((uvec3(v_pos_norm) >> uvec3(0, 8, 16)) & uvec3(0xFFu)) - 128.0;
|
2019-08-03 09:55:45 +00:00
|
|
|
|
|
|
|
f_pos = (
|
2019-09-24 06:42:09 +00:00
|
|
|
combined_mat *
|
2020-04-25 14:07:58 +00:00
|
|
|
vec4(pos, 1)).xyz;
|
|
|
|
|
2020-04-25 21:48:33 +00:00
|
|
|
f_col = srgb_to_linear(vec3((uvec3(v_col) >> uvec3(0, 8, 16)) & uvec3(0xFFu)) / 255.0);
|
2019-08-03 09:55:45 +00:00
|
|
|
|
2020-04-25 14:07:58 +00:00
|
|
|
f_ao = float(v_ao_bone & 0x3u) / 4.0;
|
2019-08-03 09:55:45 +00:00
|
|
|
|
2020-04-25 14:07:58 +00:00
|
|
|
// First 3 normals are negative, next 3 are positive
|
|
|
|
vec3 normals[6] = vec3[](vec3(-1,0,0), vec3(1,0,0), vec3(0,-1,0), vec3(0,1,0), vec3(0,0,-1), vec3(0,0,1));
|
|
|
|
vec3 norm = normals[(v_pos_norm >> 24) & 0x7u];
|
2020-04-17 20:58:36 +00:00
|
|
|
|
2019-08-03 09:55:45 +00:00
|
|
|
// Calculate normal here rather than for each pixel in the fragment shader
|
2019-09-24 06:42:09 +00:00
|
|
|
f_norm = normalize((
|
|
|
|
combined_mat *
|
2020-04-25 14:07:58 +00:00
|
|
|
vec4(norm, 0.0)
|
2019-09-24 06:42:09 +00:00
|
|
|
).xyz);
|
2019-01-11 23:18:34 +00:00
|
|
|
|
2020-04-12 22:29:59 +00:00
|
|
|
// Also precalculate shadow texture and estimated terrain altitude.
|
2020-04-25 20:23:57 +00:00
|
|
|
// f_alt = alt_at(f_pos.xy);
|
|
|
|
// f_shadow = textureBicubic(t_horizon, pos_to_tex(f_pos.xy));
|
2020-04-12 22:29:59 +00:00
|
|
|
|
2020-01-21 12:57:59 +00:00
|
|
|
gl_Position = all_mat * vec4(f_pos, 1);
|
2020-01-27 14:27:36 +00:00
|
|
|
gl_Position.z = -1000.0 / (gl_Position.z + 10000.0);
|
2019-01-11 23:18:34 +00:00
|
|
|
}
|