This example is running in WebGL2 and should work in most browsers. You can check the WebGPU examples here.
//! A shader and a material that uses it.
use ;
/// This example uses a shader source file from the assets subdirectory
const SHADER_ASSET_PATH: &str = "shaders/custom_material.wgsl";
/// set up a simple 3D scene
// This struct defines the data that will be passed to your shader
/// The Material trait is very configurable, but comes with sensible defaults for all methods.
/// You only need to implement functions for features that need non-default behavior. See the Material api docs for details!
#import bevy_pbr::forward_io::VertexOutput
// we can import items from shader modules in the assets folder with a quoted path
#import "shaders/custom_material_import.wgsl"::COLOR_MULTIPLIER
(2) (0) var<uniform> material_color: vec4<f32>;
(2) (1) var material_color_texture: texture_2d<f32>;
(2) (2) var material_color_sampler: sampler;
fn -> (0) vec4<f32> {
return material_color * * COLOR_MULTIPLIER;
}