X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=shaderlib%2Fmsp_interface.glsl;h=13cd9ccf9665a92d6603164639e1edc6099e6847;hb=54fdd850d1e657bc357d859a532497905ded741a;hp=e20e36dd555014087999c0ef86324f7f68b6a222;hpb=a3c33df71e507380100069ad7ef802b61de351bb;p=libs%2Fgl.git diff --git a/shaderlib/msp_interface.glsl b/shaderlib/msp_interface.glsl index e20e36dd..13cd9ccf 100644 --- a/shaderlib/msp_interface.glsl +++ b/shaderlib/msp_interface.glsl @@ -1,49 +1,39 @@ struct LightSourceParameters { vec4 position; - vec4 diffuse; - vec4 specular; + vec3 color; + int type; + vec3 attenuation; }; -struct ClipPlane -{ - vec4 equation; -}; - -uniform mat4 eye_obj_matrix; -uniform mat3 eye_obj_normal_matrix; -uniform Transform +uniform mat4 world_obj_matrix; +uniform mat3 world_obj_normal_matrix; +uniform CameraTransform { mat4 eye_world_matrix; - mat4 projection_matrix; + mat4 world_eye_matrix; + mat4 clip_eye_matrix; + mat4 eye_clip_matrix; }; +layout(constant_id=auto) const int max_lights = 4; uniform Lighting { - // Declared as an array for compatibility reasons - LightSourceParameters light_sources[1]; + LightSourceParameters light_sources[max_lights]; vec4 ambient_color; - vec4 sky_color; - vec3 eye_zenith_dir; - float horizon_limit; vec4 fog_color; float fog_density; }; -layout(constant_id=auto) const int max_clip_planes = 0; -uniform Clipping -{ - ClipPlane clip_planes[max_clip_planes]; -}; - #pragma MSP stage(vertex) layout(location=0) in vec4 vertex; -layout(location=8) in vec4 texcoord; -layout(location=3) in vec4 color; +layout(location=1) in vec4 color; layout(location=2) in vec3 normal; -layout(location=4) in vec3 tangent; -layout(location=5) in vec3 binormal; -layout(location=12) in vec4 instance_transform[3]; - -#pragma MSP stage(fragment) -layout(location=0) out vec4 frag_color; +layout(location=3) in vec3 tangent; +layout(location=4) in ivec4 group; +layout(location=5) in vec4 weight; +layout(location=6) in vec4 texcoord; +layout(location=7) in vec4 texcoord1; +layout(location=8) in vec4 texcoord2; +layout(location=9) in vec4 texcoord3; +layout(location=13) in vec4 instance_transform[3];