Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Merged by Bors] - Add Distance and Atmospheric Fog support #6412

Closed
wants to merge 79 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
79 commits
Select commit Hold shift + click to select a range
014a9cb
Add fog support to bevy_pbr
coreh Oct 29, 2022
6458025
Add flag to `StandardMaterial` to disable fog
coreh Oct 29, 2022
dfbd7f6
Add fog documentation
coreh Oct 29, 2022
d7afc3e
Fix example code that's failing on CI
coreh Oct 29, 2022
fb588a5
Add additional fog documentation
coreh Oct 30, 2022
0d2afb9
Make `Fog` a `Component` instead of a `Resource`
coreh Nov 1, 2022
8855bdd
Consolidate fog-related setup into `FogPlugin`
coreh Nov 1, 2022
f7fb67e
Fix example code that's failing on CI
coreh Nov 1, 2022
8c8aa79
Remove `FogMode::Off`
coreh Nov 2, 2022
d999308
Add Fog example
coreh Nov 2, 2022
c446fcc
Fix clippy issues
coreh Nov 2, 2022
2138dfc
Apply feedback on example and fix mismatched variable names
coreh Nov 3, 2022
b7c478f
Add controls table to example module documentation
coreh Nov 3, 2022
db1eca0
Add semicolon
coreh Nov 3, 2022
1e7f6c3
Merge branch 'main' into fog
coreh Nov 3, 2022
6b8a196
Rename fog component and falloff enum, for consistency and reusability
coreh Nov 3, 2022
6d2a41a
Add initial implementation of atmospheric fog and directional light s…
coreh Nov 3, 2022
7de98fd
Fix documentation broken/missing links
coreh Nov 3, 2022
505a5a2
Fix example code now that there are more fog settings
coreh Nov 3, 2022
e13c5c3
Fix clippy issue
coreh Nov 3, 2022
5d8f708
Fix the spelling of the word ‘exponent’
coreh Nov 4, 2022
e7a4a98
Use `Time::elapsed_seconds()` and `Time::delta_seconds()`
coreh Nov 4, 2022
ddb4eb9
Improve documentation, in response to PR feedback
coreh Nov 4, 2022
48295a0
Improve `GpuFog` documentation comments
coreh Nov 4, 2022
7a88d0e
Optimize/cleanup shader code
coreh Nov 4, 2022
50f0f50
Take directional light colors into account for scattering
coreh Nov 4, 2022
00226a3
Rename `scattering_color` to `directional_light_color`
coreh Nov 4, 2022
e18f682
Merge branch 'main' into fog
coreh Nov 4, 2022
e4f01e2
Merge branch 'main' into fog
coreh Nov 4, 2022
e626862
Add atmospheric fog example
coreh Nov 4, 2022
270dcd9
Fix clippy issue
coreh Nov 4, 2022
8ecba3b
Add methods for more easily configuring atmospheric fog
coreh Nov 4, 2022
68447a2
Use new visibility helper method in atmospheric fog example
coreh Nov 4, 2022
a2a5b07
Improve documentation
coreh Nov 4, 2022
a4ee547
Use `Vec3` instead of `Color` for extinction and inscattering
coreh Nov 4, 2022
e0195d3
Improve documentation
coreh Nov 4, 2022
e830d93
Add convenience methods for `FogFalloff::ExponentialSquared`
coreh Nov 4, 2022
a998fa8
Tweaks to documentation formatting and punctuation
coreh Nov 4, 2022
c608a75
Improve documentation
coreh Nov 4, 2022
aeafcc7
Remove misleading note about exponential density values
coreh Nov 4, 2022
ecea533
Fix clippy issue
coreh Nov 4, 2022
73ad380
Remove now-unnecessary UI camera
coreh Nov 4, 2022
3323542
Add comments explaining values
coreh Nov 4, 2022
92dac89
Fix documentation tests
coreh Nov 4, 2022
256fce6
Update examples/README.md
coreh Nov 4, 2022
be50d07
Merge branch 'main' into fog
coreh Nov 4, 2022
50a41cd
Use positive `fog_enabled` flag (instead of `no_fog`)
coreh Nov 4, 2022
a35783a
Add minor clarification that this is the color obtained after extinction
coreh Nov 4, 2022
8261011
Rename `result` to `fog_color` in shader
coreh Nov 4, 2022
11f1bb5
Fix search and replace mishap
coreh Nov 4, 2022
cbb330c
Use names consistent with documentation
coreh Nov 4, 2022
bf668da
Move fog to outside of `pbr()`, so that it applies to unlit materials
coreh Nov 4, 2022
e3b65c8
Merge branch 'main' into fog
coreh Nov 6, 2022
036fbd3
Add controls table and move system to last
coreh Nov 6, 2022
9f3b0c4
Improve documentation
coreh Nov 6, 2022
49a3f1e
Use “glow” instead of “halo” in explanation
coreh Nov 6, 2022
f9056c0
Improve documentation
coreh Nov 6, 2022
3c9b359
Fix constants typo in documentation comments
coreh Nov 8, 2022
e123574
Fix additional constant typos
coreh Nov 9, 2022
2664ca1
Merge branch 'main' into fog
coreh Nov 12, 2022
d54dce2
Reduce sky size, fixing (floating point precision?) flicker in WASM /…
coreh Nov 20, 2022
ccfb0ce
Merge branch 'main' into fog
coreh Nov 24, 2022
6ab1188
Break up long lines in WGSL shaders for readability
coreh Jan 15, 2023
f44e381
Remove incorrect claim that extinction factor is ‘unitless’ from docu…
coreh Jan 15, 2023
aa3fef7
Improve documentation wording
coreh Jan 15, 2023
f1cebd2
Increase font size in fog examples
coreh Jan 15, 2023
f9ceb4c
Merge branch 'main' into fog
coreh Jan 15, 2023
820a6b1
Merge branch 'main' into fog
coreh Jan 21, 2023
cd11d43
Make sure `apply_fog()` function is not defined during normal prepass
coreh Jan 21, 2023
df77ce3
Merge branch 'main' into fog
coreh Jan 21, 2023
15afdfb
Fix code for creating exponential squared fog
coreh Jan 28, 2023
c4eb571
Remove unused `KOSCHMIEDER_CONTRAST_THRESHOLD` constant
coreh Jan 28, 2023
28f4fb0
Tweak wording, remove trailing whitespace
coreh Jan 28, 2023
8b99f6f
Reorder `GpuFog` fields for better struct packing
coreh Jan 28, 2023
1e3ab2c
Extract repeated scattering code into function
coreh Jan 28, 2023
5fd6a42
Merge branch 'main' into fog
coreh Jan 28, 2023
8c4d4e9
Properly configure cascade shadow map for scene
coreh Jan 28, 2023
4608dbd
Use multiplication instead of `pow()` with `2.0`
coreh Jan 28, 2023
fee838d
Pass fragment and view positions and calculate `view_to_world` in `ap…
coreh Jan 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Improve documentation
  • Loading branch information
coreh committed Nov 6, 2022
commit f9056c06cb1979cfab61f45ae58559b592ab4b6b
36 changes: 27 additions & 9 deletions crates/bevy_pbr/src/fog.rs
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,8 @@ pub enum FogFalloff {
/// Similar to [`FogFalloff::Exponential`], but grows more slowly in intensity for closer distances
/// before “catching up”.
///
/// To move the fog “further away”, use lower density values. To move it “closer” use higher density values.
///
/// ## Tips
///
/// - Use the [`FogFalloff::from_visibility_squared()`] convenience method to create an exponential squared falloff
Expand Down Expand Up @@ -235,13 +237,19 @@ pub enum FogFalloff {
/// Additionally, individual color channels can have their own density values, resulting in a total of
/// six different configuration parameters.
///
/// ## Tips
///
/// - Use the [`FogFalloff::from_visibility_colors()`] or [`FogFalloff::from_visibility_color()`] convenience methods
/// to create an atmospheric falloff with the proper densities for a desired visibility distance in world units and
/// extinction and inscattering colors;
/// - Combine the atmospheric fog parameters with the [`FogSettings`] `color`'s alpha channel for easier artistic control.
///
/// ## Formula
///
/// Unlike other modes, atmospheric falloff doesn't use a simple intensity-based blend of fog color with
/// object color. Instead, it calculates per-channel extinction and inscattering factors, which are
/// then used to calculate the final color.
///
///
/// ```text
/// let extinction_factor = 1.0 - 1.0 / (distance * extinction).exp();
/// let inscattering_factor = 1.0 - 1.0 / (distance * inscattering).exp();
Expand All @@ -250,7 +258,7 @@ pub enum FogFalloff {
///
/// ## Equivalence to [`FogFalloff::Exponential`]
///
/// The following two falloff modes will produce identical visual results:
/// For a density value of `D`, the following two falloff modes will produce identical visual results:
///
/// ```
/// # use bevy_pbr::prelude::*;
Expand Down Expand Up @@ -296,7 +304,7 @@ pub enum FogFalloff {

impl FogFalloff {
/// Creates a [`FogFalloff::Exponential`] value from the given visibility distance in world units,
/// using the revised Koschmieder contrast threshold, [`FogFalloff::REVISED_KOSCHMIEDER_CONTRAST_THRESHOLD`]
/// using the revised Koschmieder contrast threshold, [`FogFalloff::REVISED_KOSCHMIEDER_CONTRAST_THRESHOLD`].
pub fn from_visibility(visibility: f32) -> FogFalloff {
FogFalloff::from_visibility_contrast(
visibility,
Expand All @@ -305,15 +313,15 @@ impl FogFalloff {
}

/// Creates a [`FogFalloff::Exponential`] value from the given visibility distance in world units,
/// and a given contrast threshold in the range of 0.0 to 1.0.
/// and a given contrast threshold in the range of `0.0` to `1.0`.
pub fn from_visibility_contrast(visibility: f32, contrast_threshold: f32) -> FogFalloff {
FogFalloff::Exponential {
density: FogFalloff::koschmieder(visibility, contrast_threshold),
}
}

/// Creates a [`FogFalloff::ExponentialSquared`] value from the given visibility distance in world units,
/// using the revised Koschmieder contrast threshold, [`FogFalloff::REVISED_KOSCHMIEDER_CONTRAST_THRESHOLD`]
/// using the revised Koschmieder contrast threshold, [`FogFalloff::REVISED_KOSCHMIEDER_CONTRAST_THRESHOLD`].
pub fn from_visibility_squared(visibility: f32) -> FogFalloff {
FogFalloff::from_visibility_contrast(
coreh marked this conversation as resolved.
Show resolved Hide resolved
visibility,
Expand All @@ -322,7 +330,7 @@ impl FogFalloff {
}

/// Creates a [`FogFalloff::ExponentialSquared`] value from the given visibility distance in world units,
/// and a given contrast threshold in the range of 0.0 to 1.0.
/// and a given contrast threshold in the range of `0.0` to `1.0`.
pub fn from_visibility_contrast_squared(
visibility: f32,
contrast_threshold: f32,
Expand Down Expand Up @@ -350,6 +358,11 @@ impl FogFalloff {
/// Creates a [`FogFalloff::Atmospheric`] value from the given visibility distance in world units,
/// extinction and inscattering colors, using the revised Koschmieder contrast threshold,
/// [`FogFalloff::REVISED_KOSCHMIEDER_CONTRAST_THRESHOLD`].
///
/// ## Tips
/// - Alpha values of the provided colors can modulate the `extinction` and `inscattering` effects;
/// - Using an `extinction_color` of [`Color:WHITE`] or [`Color:NONE`] disables the extinction effect;
/// - Using an `inscattering_color` of [`Color:BLACK`] or [`Color:NONE`] disables the inscattering effect.
pub fn from_visibility_colors(
visibility: f32,
extinction_color: Color,
Expand All @@ -364,7 +377,7 @@ impl FogFalloff {
}

/// Creates a [`FogFalloff::Atmospheric`] value from the given visibility distance in world units,
/// a contrast threshold in the range of 0.0 to 1.0, and a shared color for both extinction and inscattering.
/// a contrast threshold in the range of `0.0` to `1.0`, and a shared color for both extinction and inscattering.
pub fn from_visibility_contrast_color(
visibility: f32,
contrast_threshold: f32,
Expand All @@ -379,7 +392,12 @@ impl FogFalloff {
}

/// Creates a [`FogFalloff::Atmospheric`] value from the given visibility distance in world units,
/// a contrast threshold in the range of 0.0 to 1.0, extinction and inscattering colors.
/// a contrast threshold in the range of `0.0` to `1.0`, extinction and inscattering colors.
///
/// ## Tips
/// - Alpha values of the provided colors can modulate the `extinction` and `inscattering` effects;
/// - Using an `extinction_color` of [`Color:WHITE`] or [`Color:NONE`] disables the extinction effect;
/// - Using an `inscattering_color` of [`Color:BLACK`] or [`Color:NONE`] disables the inscattering effect.
pub fn from_visibility_contrast_colors(
visibility: f32,
contrast_threshold: f32,
Expand Down Expand Up @@ -417,7 +435,7 @@ impl FogFalloff {

/// Calculates the extinction coefficient β, from V and Cₜ, where:
///
/// - Cₜ is the contrast threshold, in the range of 0.0 to 1.0
/// - Cₜ is the contrast threshold, in the range of `0.0` to `1.0`
/// - V is the visibility distance in which a perfectly black object is still identifiable
/// against the horizon sky within the contrast threshold
///
Expand Down