163 lines
5.2 KiB
GLSL
163 lines
5.2 KiB
GLSL
|
#ifdef GL_ES
|
||
|
uniform sampler2D skinning_tex;
|
||
|
#else
|
||
|
uniform samplerBuffer skinning_tex;
|
||
|
#endif
|
||
|
|
||
|
layout(location = 0) in vec3 i_position;
|
||
|
#if defined(Converts_10bit_Vector)
|
||
|
layout(location = 1) in int i_normal_pked;
|
||
|
#else
|
||
|
layout(location = 1) in vec4 i_normal;
|
||
|
#endif
|
||
|
|
||
|
layout(location = 2) in vec4 i_color;
|
||
|
layout(location = 3) in vec2 i_uv;
|
||
|
layout(location = 4) in vec2 i_uv_two;
|
||
|
|
||
|
#if defined(Converts_10bit_Vector)
|
||
|
layout(location = 5) in int i_tangent_pked;
|
||
|
#else
|
||
|
layout(location = 5) in vec4 i_tangent;
|
||
|
#endif
|
||
|
|
||
|
layout(location = 6) in ivec4 i_joint;
|
||
|
layout(location = 7) in vec4 i_weight;
|
||
|
layout(location = 8) in vec3 i_origin;
|
||
|
|
||
|
#if defined(Converts_10bit_Vector)
|
||
|
layout(location = 9) in int i_rotation_pked;
|
||
|
#else
|
||
|
layout(location = 9) in vec4 i_rotation;
|
||
|
#endif
|
||
|
|
||
|
layout(location = 10) in vec4 i_scale;
|
||
|
|
||
|
#if defined(Converts_10bit_Vector)
|
||
|
layout(location = 11) in int i_misc_data_pked;
|
||
|
#else
|
||
|
layout(location = 11) in vec4 i_misc_data;
|
||
|
#endif
|
||
|
|
||
|
layout(location = 12) in int i_skinning_offset;
|
||
|
|
||
|
#if defined(Use_Bindless_Texture)
|
||
|
layout(location = 13) in uvec4 i_bindless_texture_0;
|
||
|
layout(location = 14) in uvec4 i_bindless_texture_1;
|
||
|
layout(location = 15) in uvec4 i_bindless_texture_2;
|
||
|
#elif defined(Use_Array_Texture)
|
||
|
layout(location = 13) in uvec4 i_array_texture_0;
|
||
|
layout(location = 14) in uvec2 i_array_texture_1;
|
||
|
#endif
|
||
|
|
||
|
#stk_include "utils/get_world_location.vert"
|
||
|
|
||
|
out vec3 tangent;
|
||
|
out vec3 bitangent;
|
||
|
out vec3 normal;
|
||
|
out vec2 uv;
|
||
|
out vec2 uv_two;
|
||
|
out vec4 color;
|
||
|
out float camdist;
|
||
|
flat out float hue_change;
|
||
|
|
||
|
#if defined(Use_Bindless_Texture)
|
||
|
flat out sampler2D tex_layer_0;
|
||
|
flat out sampler2D tex_layer_1;
|
||
|
flat out sampler2D tex_layer_2;
|
||
|
flat out sampler2D tex_layer_3;
|
||
|
flat out sampler2D tex_layer_4;
|
||
|
flat out sampler2D tex_layer_5;
|
||
|
#elif defined(Use_Array_Texture)
|
||
|
flat out float array_0;
|
||
|
flat out float array_1;
|
||
|
flat out float array_2;
|
||
|
flat out float array_3;
|
||
|
flat out float array_4;
|
||
|
flat out float array_5;
|
||
|
#endif
|
||
|
|
||
|
void main()
|
||
|
{
|
||
|
|
||
|
#if defined(Converts_10bit_Vector)
|
||
|
vec4 i_normal = convert10BitVector(i_normal_pked);
|
||
|
vec4 i_tangent = convert10BitVector(i_tangent_pked);
|
||
|
vec4 i_rotation = convert10BitVector(i_rotation_pked);
|
||
|
vec4 i_misc_data = convert10BitVector(i_misc_data_pked);
|
||
|
#endif
|
||
|
|
||
|
#if defined(Use_Bindless_Texture)
|
||
|
tex_layer_0 = sampler2D(i_bindless_texture_0.xy);
|
||
|
tex_layer_1 = sampler2D(i_bindless_texture_0.zw);
|
||
|
tex_layer_2 = sampler2D(i_bindless_texture_1.xy);
|
||
|
tex_layer_3 = sampler2D(i_bindless_texture_1.zw);
|
||
|
tex_layer_4 = sampler2D(i_bindless_texture_2.xy);
|
||
|
tex_layer_5 = sampler2D(i_bindless_texture_2.zw);
|
||
|
#elif defined(Use_Array_Texture)
|
||
|
array_0 = float(i_array_texture_0.x);
|
||
|
array_1 = float(i_array_texture_0.y);
|
||
|
array_2 = float(i_array_texture_0.z);
|
||
|
array_3 = float(i_array_texture_0.w);
|
||
|
array_4 = float(i_array_texture_1.x);
|
||
|
array_5 = float(i_array_texture_1.y);
|
||
|
#endif
|
||
|
|
||
|
vec4 idle_position = vec4(i_position, 1.0);
|
||
|
vec4 idle_normal = vec4(i_normal.xyz, 0.0);
|
||
|
vec4 idle_tangent = vec4(i_tangent.xyz, 0.0);
|
||
|
vec4 skinned_position = vec4(0.0);
|
||
|
vec4 skinned_normal = vec4(0.0);
|
||
|
vec4 skinned_tangent = vec4(0.0);
|
||
|
|
||
|
for (int i = 0; i < 4; i++)
|
||
|
{
|
||
|
#ifdef GL_ES
|
||
|
mat4 joint_matrix = mat4(
|
||
|
texelFetch(skinning_tex, ivec2
|
||
|
(0 , clamp(i_joint[i] + i_skinning_offset, 0, MAX_BONES)), 0),
|
||
|
texelFetch(skinning_tex, ivec2
|
||
|
(1, clamp(i_joint[i] + i_skinning_offset, 0, MAX_BONES)), 0),
|
||
|
texelFetch(skinning_tex, ivec2
|
||
|
(2, clamp(i_joint[i] + i_skinning_offset, 0, MAX_BONES)), 0),
|
||
|
texelFetch(skinning_tex, ivec2
|
||
|
(3, clamp(i_joint[i] + i_skinning_offset, 0, MAX_BONES)), 0));
|
||
|
#else
|
||
|
mat4 joint_matrix = mat4(
|
||
|
texelFetch(skinning_tex,
|
||
|
clamp(i_joint[i] + i_skinning_offset, 0, MAX_BONES) * 4),
|
||
|
texelFetch(skinning_tex,
|
||
|
clamp(i_joint[i] + i_skinning_offset, 0, MAX_BONES) * 4 + 1),
|
||
|
texelFetch(skinning_tex,
|
||
|
clamp(i_joint[i] + i_skinning_offset, 0, MAX_BONES) * 4 + 2),
|
||
|
texelFetch(skinning_tex,
|
||
|
clamp(i_joint[i] + i_skinning_offset, 0, MAX_BONES) * 4 + 3));
|
||
|
#endif
|
||
|
skinned_position += i_weight[i] * joint_matrix * idle_position;
|
||
|
skinned_normal += i_weight[i] * joint_matrix * idle_normal;
|
||
|
skinned_tangent += i_weight[i] * joint_matrix * idle_tangent;
|
||
|
}
|
||
|
|
||
|
vec4 quaternion = normalize(vec4(i_rotation.xyz, i_scale.w));
|
||
|
vec4 world_position = getWorldPosition(i_origin, quaternion, i_scale.xyz,
|
||
|
skinned_position.xyz);
|
||
|
vec3 world_normal = rotateVector(quaternion, skinned_normal.xyz);
|
||
|
vec3 world_tangent = rotateVector(quaternion, skinned_tangent.xyz);
|
||
|
|
||
|
tangent = (u_view_matrix * vec4(world_tangent, 0.0)).xyz;
|
||
|
bitangent = (u_view_matrix *
|
||
|
// bitangent sign
|
||
|
vec4(cross(world_normal, world_tangent) * i_tangent.w, 0.0)
|
||
|
).xyz;
|
||
|
normal = (u_view_matrix * vec4(world_normal, 0.0)).xyz;
|
||
|
|
||
|
uv = vec2(i_uv.x + (i_misc_data.x * i_normal.w),
|
||
|
i_uv.y + (i_misc_data.y * i_normal.w));
|
||
|
uv_two = i_uv_two;
|
||
|
|
||
|
color = i_color.zyxw;
|
||
|
camdist = length(u_view_matrix * world_position);
|
||
|
hue_change = i_misc_data.z;
|
||
|
gl_Position = u_projection_view_matrix * world_position;
|
||
|
}
|