#define_import_path bevy_pbr::skinning #import bevy_pbr::mesh_types::SkinnedMesh #ifdef SKINNED #ifdef MESH_BINDGROUP_1 @group(1) @binding(1) var joint_matrices: SkinnedMesh; #else @group(2) @binding(1) var joint_matrices: SkinnedMesh; #endif fn skin_model( indexes: vec4, weights: vec4, ) -> mat4x4 { return weights.x * joint_matrices.data[indexes.x] + weights.y * joint_matrices.data[indexes.y] + weights.z * joint_matrices.data[indexes.z] + weights.w * joint_matrices.data[indexes.w]; } fn inverse_transpose_3x3m(in: mat3x3) -> mat3x3 { let x = cross(in[1], in[2]); let y = cross(in[2], in[0]); let z = cross(in[0], in[1]); let det = dot(in[2], z); return mat3x3( x / det, y / det, z / det ); } fn skin_normals( model: mat4x4, normal: vec3, ) -> vec3 { return normalize( inverse_transpose_3x3m( mat3x3( model[0].xyz, model[1].xyz, model[2].xyz ) ) * normal ); } #endif