-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Option to enable deterministic rendering
- Loading branch information
1 parent
cfcb688
commit 1f7b932
Showing
6 changed files
with
120 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
use bevy_ecs::system::Resource; | ||
|
||
/// Configure deterministic rendering. | ||
/// | ||
/// Render is parallel by default, and in certain situations it may cause visual artifacts, | ||
/// Default fix for the issue is to set `depth_bias` per material. | ||
/// When it is not possible, deterministic rendering can be used. | ||
/// | ||
/// This option costs performance and disabled by default. | ||
#[derive(Resource, Default)] | ||
pub struct DeterministicRenderingConfig { | ||
/// Whether to enable deterministic rendering. | ||
pub deterministic: bool, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,85 @@ | ||
//! Shows how to enable deterministic rendering. Rendering is not deterministic by default. | ||
//! Note most users don't need rendering to be deterministic, and should rely on depth bias instead. | ||
use bevy::app::App; | ||
use bevy::app::Startup; | ||
use bevy::prelude::shape::Plane; | ||
use bevy::prelude::*; | ||
use bevy::render::deterministic::DeterministicRenderingConfig; | ||
|
||
fn main() { | ||
App::new() | ||
.add_plugins(DefaultPlugins) | ||
.add_systems(Startup, setup) | ||
.add_systems(Update, (keys, update_help).chain()) | ||
.run(); | ||
} | ||
|
||
fn setup( | ||
mut commands: Commands, | ||
mut materials: ResMut<Assets<StandardMaterial>>, | ||
mut meshes: ResMut<Assets<Mesh>>, | ||
mut deterministic_rendering_config: ResMut<DeterministicRenderingConfig>, | ||
) { | ||
// Safe default to avoid epileptic seizures. | ||
deterministic_rendering_config.deterministic = true; | ||
|
||
// Help message will be rendered there. | ||
commands.spawn(TextBundle::default()); | ||
|
||
commands.spawn(Camera3dBundle { | ||
transform: Transform::from_xyz(3.0, 3.0, 3.0).looking_at(Vec3::new(0., 0., 0.), Vec3::Y), | ||
..default() | ||
}); | ||
|
||
let mesh = meshes.add(Plane::from_size(2.0).into()); | ||
for i in 0..360 { | ||
let color = Color::hsl(i as f32, 1.0, 0.5); | ||
commands.spawn(PbrBundle { | ||
mesh: mesh.clone(), | ||
material: materials.add(StandardMaterial { | ||
base_color: color, | ||
// Setting depth bias would be a default choice to fix z-fighting. | ||
// When it is not possible, deterministic rendering can be used. | ||
// Here we intentionally don't use depth bias to demonstrate the issue. | ||
depth_bias: 0.0, | ||
unlit: true, | ||
..Default::default() | ||
}), | ||
..default() | ||
}); | ||
} | ||
} | ||
|
||
fn keys( | ||
mut deterministic_rendering_config: ResMut<DeterministicRenderingConfig>, | ||
keyboard_input: Res<ButtonInput<KeyCode>>, | ||
) { | ||
if keyboard_input.just_pressed(KeyCode::KeyD) { | ||
deterministic_rendering_config.deterministic ^= true; | ||
} | ||
} | ||
|
||
fn update_help( | ||
mut text: Query<&mut Text>, | ||
deterministic_rendering_config: Res<DeterministicRenderingConfig>, | ||
) { | ||
if deterministic_rendering_config.is_changed() { | ||
*text.single_mut() = Text::from_section( | ||
format!( | ||
"\ | ||
Press D to enable/disable deterministic rendering\n\ | ||
When rendering is not deterministic, you may observe z-fighting\n\ | ||
\n\ | ||
Warning: may cause seizures for people with photosensitive epilepsy\n\ | ||
\n\ | ||
Deterministic rendering: {}", | ||
deterministic_rendering_config.deterministic | ||
), | ||
TextStyle { | ||
font_size: 20., | ||
..default() | ||
}, | ||
); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters