#define_import_path bevy_sprite::mesh2d_functions #import bevy_sprite::{ mesh2d_view_bindings::view, mesh2d_bindings::mesh, } #import bevy_render::{ instance_index::get_instance_index, maths::{affine_to_square, mat2x4_f32_to_mat3x3_unpack}, } fn get_model_matrix(instance_index: u32) -> mat4x4 { return affine_to_square(mesh[get_instance_index(instance_index)].model); } fn mesh2d_position_local_to_world(model: mat4x4, vertex_position: vec4) -> vec4 { return model * vertex_position; } fn mesh2d_position_world_to_clip(world_position: vec4) -> vec4 { return view.view_proj * world_position; } // NOTE: The intermediate world_position assignment is important // for precision purposes when using the 'equals' depth comparison // function. fn mesh2d_position_local_to_clip(model: mat4x4, vertex_position: vec4) -> vec4 { let world_position = mesh2d_position_local_to_world(model, vertex_position); return mesh2d_position_world_to_clip(world_position); } fn mesh2d_normal_local_to_world(vertex_normal: vec3, instance_index: u32) -> vec3 { return mat2x4_f32_to_mat3x3_unpack( mesh[instance_index].inverse_transpose_model_a, mesh[instance_index].inverse_transpose_model_b, ) * vertex_normal; } fn mesh2d_tangent_local_to_world(model: mat4x4, vertex_tangent: vec4) -> vec4 { return vec4( mat3x3( model[0].xyz, model[1].xyz, model[2].xyz ) * vertex_tangent.xyz, vertex_tangent.w ); }