2019-01-11 23:18:34 +00:00
|
|
|
#version 330 core
|
|
|
|
|
2019-05-12 09:10:13 +00:00
|
|
|
#include <globals.glsl>
|
|
|
|
|
2019-01-11 23:18:34 +00:00
|
|
|
in vec3 f_pos;
|
2019-01-14 14:18:58 +00:00
|
|
|
in vec3 f_norm;
|
2019-01-13 20:53:55 +00:00
|
|
|
in vec3 f_col;
|
2019-01-14 23:13:58 +00:00
|
|
|
flat in uint f_bone_idx;
|
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;
|
2019-01-11 23:18:34 +00:00
|
|
|
};
|
|
|
|
|
2019-01-14 23:13:58 +00:00
|
|
|
struct BoneData {
|
|
|
|
mat4 bone_mat;
|
|
|
|
};
|
|
|
|
|
|
|
|
layout (std140)
|
|
|
|
uniform u_bones {
|
|
|
|
BoneData bones[16];
|
|
|
|
};
|
|
|
|
|
2019-01-11 23:18:34 +00:00
|
|
|
out vec4 tgt_color;
|
|
|
|
|
|
|
|
void main() {
|
2019-01-14 23:13:58 +00:00
|
|
|
vec3 world_norm = (
|
|
|
|
model_mat *
|
|
|
|
bones[f_bone_idx].bone_mat *
|
|
|
|
vec4(f_norm, 0.0)
|
|
|
|
).xyz;
|
2019-01-14 14:18:58 +00:00
|
|
|
|
|
|
|
float ambient = 0.5;
|
|
|
|
|
|
|
|
vec3 sun_dir = normalize(vec3(1.3, 1.7, 1.1));
|
|
|
|
|
|
|
|
float sun_diffuse = dot(sun_dir, world_norm) * 0.5;
|
|
|
|
|
2019-05-13 13:58:01 +00:00
|
|
|
tgt_color = model_col * vec4(f_col * (ambient + sun_diffuse), 1.0);
|
2019-01-11 23:18:34 +00:00
|
|
|
}
|