From 9f8c72a7381d5924d551089678a96e61b9ce30b7 Mon Sep 17 00:00:00 2001 From: Aevyrie Date: Mon, 10 Jul 2023 23:55:41 -0700 Subject: [PATCH] completely remove `bevy_pbr` dependencies --- Cargo.toml | 2 +- src/material.rs | 48 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 49 insertions(+), 1 deletion(-) diff --git a/Cargo.toml b/Cargo.toml index 6fc1046..e8fa50b 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -21,7 +21,6 @@ bitflags = "2.3" bevy = { version = "0.11.0", default-features = false, features = [ "bevy_core_pipeline", "bevy_render", - "bevy_pbr", "bevy_asset", ] } @@ -35,6 +34,7 @@ rand = "0.8.4" ringbuffer = "0.14" bevy = { version = "0.11.0", default-features = false, features = [ "bevy_winit", + "bevy_pbr", "x11", "tonemapping_luts", "ktx2", diff --git a/src/material.rs b/src/material.rs index 5b8aaff..ed9eab2 100644 --- a/src/material.rs +++ b/src/material.rs @@ -393,3 +393,51 @@ pub fn queue_material_polylines( } } } + +/// Sets how a material's base color alpha channel is used for transparency. +#[derive(Debug, Default, Reflect, Copy, Clone, PartialEq)] +#[reflect(Default, Debug)] +pub enum AlphaMode { + /// Base color alpha values are overridden to be fully opaque (1.0). + #[default] + Opaque, + /// Reduce transparency to fully opaque or fully transparent + /// based on a threshold. + /// + /// Compares the base color alpha value to the specified threshold. + /// If the value is below the threshold, + /// considers the color to be fully transparent (alpha is set to 0.0). + /// If it is equal to or above the threshold, + /// considers the color to be fully opaque (alpha is set to 1.0). + Mask(f32), + /// The base color alpha value defines the opacity of the color. + /// Standard alpha-blending is used to blend the fragment's color + /// with the color behind it. + Blend, + /// Similar to [`AlphaMode::Blend`], however assumes RGB channel values are + /// [premultiplied](https://en.wikipedia.org/wiki/Alpha_compositing#Straight_versus_premultiplied). + /// + /// For otherwise constant RGB values, behaves more like [`AlphaMode::Blend`] for + /// alpha values closer to 1.0, and more like [`AlphaMode::Add`] for + /// alpha values closer to 0.0. + /// + /// Can be used to avoid “border” or “outline” artifacts that can occur + /// when using plain alpha-blended textures. + Premultiplied, + /// Combines the color of the fragments with the colors behind them in an + /// additive process, (i.e. like light) producing lighter results. + /// + /// Black produces no effect. Alpha values can be used to modulate the result. + /// + /// Useful for effects like holograms, ghosts, lasers and other energy beams. + Add, + /// Combines the color of the fragments with the colors behind them in a + /// multiplicative process, (i.e. like pigments) producing darker results. + /// + /// White produces no effect. Alpha values can be used to modulate the result. + /// + /// Useful for effects like stained glass, window tint film and some colored liquids. + Multiply, +} + +impl Eq for AlphaMode {}