2016-12-09 05:41:13 -05:00
|
|
|
#ifdef GL_ES
|
|
|
|
uniform mat4 ModelMatrix;
|
|
|
|
uniform mat4 InverseModelMatrix;
|
|
|
|
uniform vec2 texture_trans;
|
|
|
|
#else
|
|
|
|
uniform mat4 ModelMatrix =
|
|
|
|
mat4(1., 0., 0., 0.,
|
|
|
|
0., 1., 0., 0.,
|
|
|
|
0., 0., 1., 0.,
|
|
|
|
0., 0., 0., 1.);
|
|
|
|
uniform mat4 InverseModelMatrix =
|
|
|
|
mat4(1., 0., 0., 0.,
|
|
|
|
0., 1., 0., 0.,
|
|
|
|
0., 0., 1., 0.,
|
|
|
|
0., 0., 0., 1.);
|
2013-11-06 18:17:18 -05:00
|
|
|
|
2016-12-09 05:41:13 -05:00
|
|
|
uniform vec2 texture_trans = vec2(0., 0.);
|
|
|
|
#endif
|
|
|
|
uniform int skinning_offset;
|
2011-07-15 19:38:40 -04:00
|
|
|
|
2017-02-01 15:58:10 -05:00
|
|
|
#ifdef Explicit_Attrib_Location_Usable
|
2016-12-09 05:41:13 -05:00
|
|
|
layout(location = 0) in vec3 Position;
|
|
|
|
layout(location = 1) in vec3 Normal;
|
|
|
|
layout(location = 2) in vec4 Color;
|
|
|
|
layout(location = 3) in vec4 Data1;
|
|
|
|
layout(location = 4) in vec4 Data2;
|
|
|
|
layout(location = 5) in ivec4 Joint;
|
|
|
|
layout(location = 6) in vec4 Weight;
|
2016-12-22 12:31:13 -05:00
|
|
|
#else
|
|
|
|
in vec3 Position;
|
|
|
|
in vec3 Normal;
|
|
|
|
in vec4 Color;
|
|
|
|
in vec4 Data1;
|
|
|
|
in vec4 Data2;
|
|
|
|
in ivec4 Joint;
|
|
|
|
in vec4 Weight;
|
|
|
|
#endif
|
2011-07-15 19:38:40 -04:00
|
|
|
|
2016-12-09 05:41:13 -05:00
|
|
|
out vec3 nor;
|
|
|
|
out vec3 tangent;
|
|
|
|
out vec3 bitangent;
|
|
|
|
out vec2 uv;
|
|
|
|
out vec4 color;
|
2013-06-18 10:35:29 -04:00
|
|
|
|
2016-12-09 05:41:13 -05:00
|
|
|
#stk_include "utils/getworldmatrix.vert"
|
2011-07-15 19:38:40 -04:00
|
|
|
|
2016-12-09 05:41:13 -05:00
|
|
|
void main(void)
|
|
|
|
{
|
|
|
|
mat4 TransposeInverseModelView = transpose(InverseModelMatrix * InverseViewMatrix);
|
|
|
|
vec4 idle_position = vec4(Position, 1.);
|
|
|
|
vec4 idle_normal = vec4(Normal, 0.);
|
2016-12-14 20:52:02 -05:00
|
|
|
vec4 idle_tangent = vec4(Data1.z, Data1.w, Data2.x, 0.);
|
|
|
|
vec4 idle_bitangent = vec4(Data2.y, Data2.z, Data2.w, 0.);
|
2016-12-09 05:41:13 -05:00
|
|
|
vec4 skinned_position = vec4(0.);
|
|
|
|
vec4 skinned_normal = vec4(0.);
|
2016-12-14 03:28:37 -05:00
|
|
|
vec4 skinned_tangent = vec4(0.);
|
|
|
|
vec4 skinned_bitangent = vec4(0.);
|
2016-12-09 05:41:13 -05:00
|
|
|
// Note : For normal we assume no scale factor in bone (otherwise we'll have to compute inversematrix for each bones...)
|
2016-12-09 10:21:41 -05:00
|
|
|
for (int i = 0; i < 4; i++)
|
|
|
|
{
|
|
|
|
vec4 single_bone_influenced_position = joint_matrices[clamp(Joint[i] + skinning_offset, 0, MAX_BONES)] * idle_position;
|
|
|
|
single_bone_influenced_position /= single_bone_influenced_position.w;
|
|
|
|
vec4 single_bone_influenced_normal = joint_matrices[clamp(Joint[i] + skinning_offset, 0, MAX_BONES)] * idle_normal;
|
2016-12-14 03:28:37 -05:00
|
|
|
vec4 single_bone_influenced_tangent = joint_matrices[clamp(Joint[i] + skinning_offset, 0, MAX_BONES)] * idle_tangent;
|
|
|
|
vec4 single_bone_influenced_bitangent = joint_matrices[clamp(Joint[i] + skinning_offset, 0, MAX_BONES)] * idle_bitangent;
|
2016-12-09 10:21:41 -05:00
|
|
|
skinned_position += Weight[i] * single_bone_influenced_position;
|
|
|
|
skinned_normal += Weight[i] * single_bone_influenced_normal;
|
2016-12-14 03:28:37 -05:00
|
|
|
skinned_tangent += Weight[i] * single_bone_influenced_tangent;
|
|
|
|
skinned_bitangent += Weight[i] * single_bone_influenced_bitangent;
|
2016-12-09 10:21:41 -05:00
|
|
|
}
|
2013-06-18 10:35:29 -04:00
|
|
|
|
2016-12-23 06:22:30 -05:00
|
|
|
gl_Position = ProjectionViewMatrix * ModelMatrix * skinned_position;
|
2016-12-09 05:41:13 -05:00
|
|
|
// Keep orthogonality
|
|
|
|
nor = (TransposeInverseModelView * skinned_normal).xyz;
|
|
|
|
// Keep direction
|
2016-12-14 03:28:37 -05:00
|
|
|
tangent = (ViewMatrix * ModelMatrix * skinned_tangent).xyz;
|
|
|
|
bitangent = (ViewMatrix * ModelMatrix * skinned_bitangent).xyz;
|
2016-12-09 05:41:13 -05:00
|
|
|
uv = vec2(Data1.x + texture_trans.x, Data1.y + texture_trans.y);
|
|
|
|
color = Color.zyxw;
|
2011-07-15 19:38:40 -04:00
|
|
|
}
|