bevy/examples/2d
Robert Swain b333386271 Add reusable shader functions for transforming position/normal/tangent (#4901)
# Objective

- Add reusable shader functions for transforming positions / normals / tangents between local and world / clip space for 2D and 3D so that they are done in a simple and correct way
- The next step in #3969 so check there for more details.

## Solution

- Add `bevy_pbr::mesh_functions` and `bevy_sprite::mesh2d_functions` shader imports
  - These contain `mesh_` and `mesh2d_` versions of the following functions:
    - `mesh_position_local_to_world`
    - `mesh_position_world_to_clip`
    - `mesh_position_local_to_clip`
    - `mesh_normal_local_to_world`
    - `mesh_tangent_local_to_world`
- Use them everywhere where it is appropriate
  - Notably not in the sprite and UI shaders where `mesh2d_position_world_to_clip` could have been used, but including all the functions depends on the mesh binding so I chose to not use the function there
- NOTE: The `mesh_` and `mesh2d_` functions are currently identical. However, if I had defined only `bevy_pbr::mesh_functions` and used that in bevy_sprite, then bevy_sprite would have a runtime dependency on bevy_pbr, which seems undesirable. I also expect that when we have a proper 2D rendering API, these functions will diverge between 2D and 3D.

---

## Changelog

- Added: `bevy_pbr::mesh_functions` and `bevy_sprite::mesh2d_functions` shader imports containing `mesh_` and `mesh2d_` versions of the following functions:
  - `mesh_position_local_to_world`
  - `mesh_position_world_to_clip`
  - `mesh_position_local_to_clip`
  - `mesh_normal_local_to_world`
  - `mesh_tangent_local_to_world`

## Migration Guide

- The `skin_tangents` function from the `bevy_pbr::skinning` shader import has been replaced with the `mesh_tangent_local_to_world` function from the `bevy_pbr::mesh_functions` shader import
2022-06-14 00:32:33 +00:00
..
mesh2d.rs Camera Driven Rendering (#4745) 2022-06-02 00:12:17 +00:00
mesh2d_manual.rs Add reusable shader functions for transforming position/normal/tangent (#4901) 2022-06-14 00:32:33 +00:00
mesh2d_vertex_color_texture.rs Camera Driven Rendering (#4745) 2022-06-02 00:12:17 +00:00
move_sprite.rs Camera Driven Rendering (#4745) 2022-06-02 00:12:17 +00:00
rotation.rs Camera Driven Rendering (#4745) 2022-06-02 00:12:17 +00:00
shapes.rs Camera Driven Rendering (#4745) 2022-06-02 00:12:17 +00:00
sprite.rs Camera Driven Rendering (#4745) 2022-06-02 00:12:17 +00:00
sprite_flipping.rs Camera Driven Rendering (#4745) 2022-06-02 00:12:17 +00:00
sprite_sheet.rs Change default Image FilterMode to Linear (#4465) 2022-06-11 09:13:37 +00:00
text2d.rs Camera Driven Rendering (#4745) 2022-06-02 00:12:17 +00:00
texture_atlas.rs Change default Image FilterMode to Linear (#4465) 2022-06-11 09:13:37 +00:00
transparency_2d.rs use the default() method in examples instead of Default::default() (#4952) 2022-06-07 02:16:47 +00:00