#version 330 core #include in vec3 f_pos; in vec3 f_norm; in vec3 f_col; flat in uint f_bone_idx; layout (std140) uniform u_locals { mat4 model_mat; vec4 model_col; }; struct BoneData { mat4 bone_mat; }; layout (std140) uniform u_bones { BoneData bones[16]; }; out vec4 tgt_color; void main() { vec3 world_norm = ( model_mat * bones[f_bone_idx].bone_mat * vec4(f_norm, 0.0) ).xyz; 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; tgt_color = model_col * vec4(f_col * (ambient + sun_diffuse), 1.0); }