mirror of
https://github.com/bevyengine/bevy
synced 2024-11-10 07:04:33 +00:00
71cf35ce42
# Objective - Use the prepass textures in webgl ## Solution - Bind the prepass textures even when using webgl, but only if msaa is disabled - Also did some refactors to centralize how textures are bound, similar to the EnvironmentMapLight PR - ~~Also did some refactors of the example to make it work in webgl~~ - ~~To make the example work in webgl, I needed to use a sampler for the depth texture, the resulting code looks a bit weird, but it's simple enough and I think it's worth it to show how it works when using webgl~~
29 lines
782 B
WebGPU Shading Language
29 lines
782 B
WebGPU Shading Language
#import bevy_pbr::mesh_types
|
|
#import bevy_pbr::mesh_view_bindings
|
|
#import bevy_pbr::prepass_utils
|
|
|
|
struct ShowPrepassSettings {
|
|
show_depth: u32,
|
|
show_normals: u32,
|
|
padding_1: u32,
|
|
padding_2: u32,
|
|
}
|
|
@group(1) @binding(0)
|
|
var<uniform> settings: ShowPrepassSettings;
|
|
|
|
@fragment
|
|
fn fragment(
|
|
@builtin(position) frag_coord: vec4<f32>,
|
|
@builtin(sample_index) sample_index: u32,
|
|
#import bevy_pbr::mesh_vertex_output
|
|
) -> @location(0) vec4<f32> {
|
|
if settings.show_depth == 1u {
|
|
let depth = prepass_depth(frag_coord, sample_index);
|
|
return vec4(depth, depth, depth, 1.0);
|
|
} else if settings.show_normals == 1u {
|
|
let normal = prepass_normal(frag_coord, sample_index);
|
|
return vec4(normal, 1.0);
|
|
}
|
|
|
|
return vec4(0.0);
|
|
}
|