2023-10-12 22:10:38 +00:00
|
|
|
#define_import_path bevy_pbr::pbr_prepass_functions
|
|
|
|
|
2023-10-21 11:51:58 +00:00
|
|
|
#import bevy_pbr::{
|
|
|
|
prepass_io::VertexOutput,
|
2024-04-07 18:59:16 +00:00
|
|
|
prepass_bindings::previous_view_uniforms,
|
2023-10-21 11:51:58 +00:00
|
|
|
mesh_view_bindings::view,
|
|
|
|
pbr_bindings,
|
|
|
|
pbr_types,
|
|
|
|
}
|
2023-10-12 22:10:38 +00:00
|
|
|
|
2024-04-15 20:37:52 +00:00
|
|
|
// Cutoff used for the premultiplied alpha modes BLEND, ADD, and ALPHA_TO_COVERAGE.
|
2023-10-12 22:10:38 +00:00
|
|
|
const PREMULTIPLIED_ALPHA_CUTOFF = 0.05;
|
|
|
|
|
|
|
|
// We can use a simplified version of alpha_discard() here since we only need to handle the alpha_cutoff
|
2023-10-13 19:12:40 +00:00
|
|
|
fn prepass_alpha_discard(in: VertexOutput) {
|
2023-10-12 22:10:38 +00:00
|
|
|
|
|
|
|
#ifdef MAY_DISCARD
|
|
|
|
var output_color: vec4<f32> = pbr_bindings::material.base_color;
|
|
|
|
|
|
|
|
#ifdef VERTEX_UVS
|
2024-05-18 22:28:31 +00:00
|
|
|
#ifdef STANDARD_MATERIAL_BASE_COLOR_UV_B
|
2024-05-13 18:23:09 +00:00
|
|
|
var uv = in.uv_b;
|
2024-05-18 22:28:31 +00:00
|
|
|
#else // STANDARD_MATERIAL_BASE_COLOR_UV_B
|
|
|
|
var uv = in.uv;
|
|
|
|
#endif // STANDARD_MATERIAL_BASE_COLOR_UV_B
|
|
|
|
|
2024-02-25 22:42:28 +00:00
|
|
|
let uv_transform = pbr_bindings::material.uv_transform;
|
2024-05-13 18:23:09 +00:00
|
|
|
uv = (uv_transform * vec3(uv, 1.0)).xy;
|
2023-10-12 22:10:38 +00:00
|
|
|
if (pbr_bindings::material.flags & pbr_types::STANDARD_MATERIAL_FLAGS_BASE_COLOR_TEXTURE_BIT) != 0u {
|
2024-02-21 01:11:28 +00:00
|
|
|
output_color = output_color * textureSampleBias(pbr_bindings::base_color_texture, pbr_bindings::base_color_sampler, uv, view.mip_bias);
|
2023-10-12 22:10:38 +00:00
|
|
|
}
|
|
|
|
#endif // VERTEX_UVS
|
|
|
|
|
|
|
|
let alpha_mode = pbr_bindings::material.flags & pbr_types::STANDARD_MATERIAL_FLAGS_ALPHA_MODE_RESERVED_BITS;
|
|
|
|
if alpha_mode == pbr_types::STANDARD_MATERIAL_FLAGS_ALPHA_MODE_MASK {
|
|
|
|
if output_color.a < pbr_bindings::material.alpha_cutoff {
|
|
|
|
discard;
|
|
|
|
}
|
2024-04-15 20:37:52 +00:00
|
|
|
} else if (alpha_mode == pbr_types::STANDARD_MATERIAL_FLAGS_ALPHA_MODE_BLEND ||
|
|
|
|
alpha_mode == pbr_types::STANDARD_MATERIAL_FLAGS_ALPHA_MODE_ADD ||
|
|
|
|
alpha_mode == pbr_types::STANDARD_MATERIAL_FLAGS_ALPHA_MODE_ALPHA_TO_COVERAGE) {
|
2023-10-12 22:10:38 +00:00
|
|
|
if output_color.a < PREMULTIPLIED_ALPHA_CUTOFF {
|
|
|
|
discard;
|
|
|
|
}
|
|
|
|
} else if alpha_mode == pbr_types::STANDARD_MATERIAL_FLAGS_ALPHA_MODE_PREMULTIPLIED {
|
|
|
|
if all(output_color < vec4(PREMULTIPLIED_ALPHA_CUTOFF)) {
|
|
|
|
discard;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // MAY_DISCARD
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef MOTION_VECTOR_PREPASS
|
|
|
|
fn calculate_motion_vector(world_position: vec4<f32>, previous_world_position: vec4<f32>) -> vec2<f32> {
|
Normalise matrix naming (#13489)
# Objective
- Fixes #10909
- Fixes #8492
## Solution
- Name all matrices `x_from_y`, for example `world_from_view`.
## Testing
- I've tested most of the 3D examples. The `lighting` example
particularly should hit a lot of the changes and appears to run fine.
---
## Changelog
- Renamed matrices across the engine to follow a `y_from_x` naming,
making the space conversion more obvious.
## Migration Guide
- `Frustum`'s `from_view_projection`, `from_view_projection_custom_far`
and `from_view_projection_no_far` were renamed to
`from_clip_from_world`, `from_clip_from_world_custom_far` and
`from_clip_from_world_no_far`.
- `ComputedCameraValues::projection_matrix` was renamed to
`clip_from_view`.
- `CameraProjection::get_projection_matrix` was renamed to
`get_clip_from_view` (this affects implementations on `Projection`,
`PerspectiveProjection` and `OrthographicProjection`).
- `ViewRangefinder3d::from_view_matrix` was renamed to
`from_world_from_view`.
- `PreviousViewData`'s members were renamed to `view_from_world` and
`clip_from_world`.
- `ExtractedView`'s `projection`, `transform` and `view_projection` were
renamed to `clip_from_view`, `world_from_view` and `clip_from_world`.
- `ViewUniform`'s `view_proj`, `unjittered_view_proj`,
`inverse_view_proj`, `view`, `inverse_view`, `projection` and
`inverse_projection` were renamed to `clip_from_world`,
`unjittered_clip_from_world`, `world_from_clip`, `world_from_view`,
`view_from_world`, `clip_from_view` and `view_from_clip`.
- `GpuDirectionalCascade::view_projection` was renamed to
`clip_from_world`.
- `MeshTransforms`' `transform` and `previous_transform` were renamed to
`world_from_local` and `previous_world_from_local`.
- `MeshUniform`'s `transform`, `previous_transform`,
`inverse_transpose_model_a` and `inverse_transpose_model_b` were renamed
to `world_from_local`, `previous_world_from_local`,
`local_from_world_transpose_a` and `local_from_world_transpose_b` (the
`Mesh` type in WGSL mirrors this, however `transform` and
`previous_transform` were named `model` and `previous_model`).
- `Mesh2dTransforms::transform` was renamed to `world_from_local`.
- `Mesh2dUniform`'s `transform`, `inverse_transpose_model_a` and
`inverse_transpose_model_b` were renamed to `world_from_local`,
`local_from_world_transpose_a` and `local_from_world_transpose_b` (the
`Mesh2d` type in WGSL mirrors this).
- In WGSL, in `bevy_pbr::mesh_functions`, `get_model_matrix` and
`get_previous_model_matrix` were renamed to `get_world_from_local` and
`get_previous_world_from_local`.
- In WGSL, `bevy_sprite::mesh2d_functions::get_model_matrix` was renamed
to `get_world_from_local`.
2024-06-03 16:56:53 +00:00
|
|
|
let clip_position_t = view.unjittered_clip_from_world * world_position;
|
2023-10-12 22:10:38 +00:00
|
|
|
let clip_position = clip_position_t.xy / clip_position_t.w;
|
Normalise matrix naming (#13489)
# Objective
- Fixes #10909
- Fixes #8492
## Solution
- Name all matrices `x_from_y`, for example `world_from_view`.
## Testing
- I've tested most of the 3D examples. The `lighting` example
particularly should hit a lot of the changes and appears to run fine.
---
## Changelog
- Renamed matrices across the engine to follow a `y_from_x` naming,
making the space conversion more obvious.
## Migration Guide
- `Frustum`'s `from_view_projection`, `from_view_projection_custom_far`
and `from_view_projection_no_far` were renamed to
`from_clip_from_world`, `from_clip_from_world_custom_far` and
`from_clip_from_world_no_far`.
- `ComputedCameraValues::projection_matrix` was renamed to
`clip_from_view`.
- `CameraProjection::get_projection_matrix` was renamed to
`get_clip_from_view` (this affects implementations on `Projection`,
`PerspectiveProjection` and `OrthographicProjection`).
- `ViewRangefinder3d::from_view_matrix` was renamed to
`from_world_from_view`.
- `PreviousViewData`'s members were renamed to `view_from_world` and
`clip_from_world`.
- `ExtractedView`'s `projection`, `transform` and `view_projection` were
renamed to `clip_from_view`, `world_from_view` and `clip_from_world`.
- `ViewUniform`'s `view_proj`, `unjittered_view_proj`,
`inverse_view_proj`, `view`, `inverse_view`, `projection` and
`inverse_projection` were renamed to `clip_from_world`,
`unjittered_clip_from_world`, `world_from_clip`, `world_from_view`,
`view_from_world`, `clip_from_view` and `view_from_clip`.
- `GpuDirectionalCascade::view_projection` was renamed to
`clip_from_world`.
- `MeshTransforms`' `transform` and `previous_transform` were renamed to
`world_from_local` and `previous_world_from_local`.
- `MeshUniform`'s `transform`, `previous_transform`,
`inverse_transpose_model_a` and `inverse_transpose_model_b` were renamed
to `world_from_local`, `previous_world_from_local`,
`local_from_world_transpose_a` and `local_from_world_transpose_b` (the
`Mesh` type in WGSL mirrors this, however `transform` and
`previous_transform` were named `model` and `previous_model`).
- `Mesh2dTransforms::transform` was renamed to `world_from_local`.
- `Mesh2dUniform`'s `transform`, `inverse_transpose_model_a` and
`inverse_transpose_model_b` were renamed to `world_from_local`,
`local_from_world_transpose_a` and `local_from_world_transpose_b` (the
`Mesh2d` type in WGSL mirrors this).
- In WGSL, in `bevy_pbr::mesh_functions`, `get_model_matrix` and
`get_previous_model_matrix` were renamed to `get_world_from_local` and
`get_previous_world_from_local`.
- In WGSL, `bevy_sprite::mesh2d_functions::get_model_matrix` was renamed
to `get_world_from_local`.
2024-06-03 16:56:53 +00:00
|
|
|
let previous_clip_position_t = previous_view_uniforms.clip_from_world * previous_world_position;
|
2023-10-12 22:10:38 +00:00
|
|
|
let previous_clip_position = previous_clip_position_t.xy / previous_clip_position_t.w;
|
|
|
|
// These motion vectors are used as offsets to UV positions and are stored
|
|
|
|
// in the range -1,1 to allow offsetting from the one corner to the
|
|
|
|
// diagonally-opposite corner in UV coordinates, in either direction.
|
|
|
|
// A difference between diagonally-opposite corners of clip space is in the
|
|
|
|
// range -2,2, so this needs to be scaled by 0.5. And the V direction goes
|
|
|
|
// down where clip space y goes up, so y needs to be flipped.
|
|
|
|
return (clip_position - previous_clip_position) * vec2(0.5, -0.5);
|
|
|
|
}
|
2023-10-13 19:12:40 +00:00
|
|
|
#endif // MOTION_VECTOR_PREPASS
|