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] - Rebase of existing PBR work #1554

Closed
wants to merge 58 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
58 commits
Select commit Hold shift + click to select a range
13c552a
semi working pbr.
StarArawn Mar 7, 2021
cc1a4ba
More changes.
StarArawn Mar 4, 2021
8975234
Removed unused vars.
StarArawn Aug 19, 2020
13d1629
example/pbr added, example/msaa restored to a simple box
IngmarBitter Dec 29, 2020
13a9baa
to fix: spheres appear in default color, not the one specified in the…
IngmarBitter Dec 29, 2020
5ef2912
vary key PBR parameters on a grid of spheres to show the effect
IngmarBitter Dec 29, 2020
5a5e1ae
Improve example PBR parameter calculation
mtsr Mar 4, 2021
1a2e022
Remove unused variable and comments
mtsr Mar 4, 2021
0ebeb11
Use from_xyz
mtsr Mar 4, 2021
f8c3c7c
Correct default roughness/metallic
mtsr Mar 4, 2021
96dce66
Add perceptualRoughness->roughness and clamping
mtsr Mar 4, 2021
c9cc858
Remove commented code
mtsr Mar 5, 2021
56dd585
Reorder fields
mtsr Mar 5, 2021
314b64f
whitespace
mtsr Mar 6, 2021
e55ff3e
Use world position
mtsr Mar 6, 2021
3b3e33a
Rework, fix and document
mtsr Mar 6, 2021
dd9f2bc
Rename albedo->base_color, pbr->roughness/metallic
mtsr Mar 7, 2021
f8e744d
Add reflectance material property
mtsr Mar 6, 2021
08afa11
Add .clang-format for GLSL
mtsr Mar 6, 2021
81523f8
Document standard PBR properties
mtsr Mar 7, 2021
177ece9
Add comment to base_color_factor mentioning albedo
mtsr Mar 7, 2021
d1c2e41
Swizzle using .rgb for colors
mtsr Mar 7, 2021
f0a8cbf
Document attenuation and light accumulation
mtsr Mar 7, 2021
f6f15f8
Fix #ifdef STANDARDMATERIAL_BASE_COLOR_TEXTURE
mtsr Mar 7, 2021
0944cd8
Add reinhard_luminance tonemapping
mtsr Mar 7, 2021
2c3e5e5
Fix examples by adding light radius of 20.0
mtsr Mar 7, 2021
b989da5
Fix wireframe example
mtsr Mar 7, 2021
c2c965c
Rename light.radius to light.range
mtsr Mar 7, 2021
ac7a88e
Adjust comments
mtsr Mar 7, 2021
da36141
Remove 1/4PI term
mtsr Mar 7, 2021
2f6ccce
Add most basic ambient term
mtsr Mar 8, 2021
917d1cf
Disable gamma correction
mtsr Mar 8, 2021
a3fb860
Add PBR parameter newtypes/enums for CPU remapping
mtsr Mar 8, 2021
07f2f9f
Use gold in pbr example
mtsr Mar 8, 2021
f720ffc
Revert "Add PBR parameter newtypes/enums for CPU remapping"
mtsr Mar 9, 2021
85a695e
Add comment about not using mix
mtsr Mar 9, 2021
79a4d0a
Fix bad commit
mtsr Mar 9, 2021
c57e56d
Hoist NdotV out of light loop
mtsr Mar 9, 2021
4b358ba
Move light closer in pbr example
mtsr Mar 9, 2021
fdc07ab
Better ambient term
mtsr Mar 9, 2021
aaafa67
Remove unused imports
mtsr Mar 9, 2021
39c6b28
Remove unused import
mtsr Mar 9, 2021
c3d1085
Fix failing test
mtsr Mar 10, 2021
0eb6a1b
Premultiply light color by intensity
mtsr Mar 10, 2021
2dad217
Calculate buffer_size once
mtsr Mar 10, 2021
ca2b45a
Extend default light range, simplifying examples
mtsr Mar 10, 2021
9826371
Added additional comment to roughness default
mtsr Mar 11, 2021
25b14dc
Remove `_factor` from StandardMaterial properties
mtsr Mar 12, 2021
23bd4b3
Remove .clang-format
mtsr Mar 12, 2021
1666f45
Remove `forward` in pipeline naming
mtsr Mar 12, 2021
97d034a
Clear and consistent input/output naming
mtsr Mar 12, 2021
f623307
Add PBR example to example README.md
mtsr Mar 13, 2021
20984af
Remove unused v_Position and clean up
mtsr Mar 13, 2021
9cbb811
Remove comment about 'aspirational' name pbr
mtsr Mar 16, 2021
36d5608
Uncomment `//unused float` in pbr.frag
mtsr Mar 16, 2021
1d4d606
Add camera position and update shaders
cart Mar 19, 2021
5f47748
increase default intensity
cart Mar 19, 2021
243b7dc
rename "pipeline" to "pbr_pipeline"
cart Mar 19, 2021
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
4 changes: 4 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,10 @@ path = "examples/3d/orthographic.rs"
name = "parenting"
path = "examples/3d/parenting.rs"

[[example]]
name = "pbr"
path = "examples/3d/pbr.rs"

[[example]]
name = "spawner"
path = "examples/3d/spawner.rs"
Expand Down
7 changes: 5 additions & 2 deletions crates/bevy_gltf/src/loader.rs
Original file line number Diff line number Diff line change
Expand Up @@ -277,9 +277,12 @@ fn load_material(material: &Material, load_context: &mut LoadContext) -> Handle<
load_context.set_labeled_asset(
&material_label,
LoadedAsset::new(StandardMaterial {
albedo: Color::rgba(color[0], color[1], color[2], color[3]),
albedo_texture: texture_handle,
base_color: Color::rgba(color[0], color[1], color[2], color[3]),
base_color_texture: texture_handle,
roughness: pbr.roughness_factor(),
metallic: pbr.metallic_factor(),
unlit: material.unlit(),
..Default::default()
})
.with_dependencies(dependencies),
)
Expand Down
1 change: 0 additions & 1 deletion crates/bevy_internal/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,6 @@ pub mod gltf {
#[cfg(feature = "bevy_pbr")]
pub mod pbr {
//! Physically based rendering.
//! **Note**: true PBR has not yet been implemented; the name `pbr` is aspirational.
pub use bevy_pbr::*;
}

Expand Down
4 changes: 2 additions & 2 deletions crates/bevy_pbr/src/entity.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use crate::{light::Light, material::StandardMaterial, render_graph::FORWARD_PIPELINE_HANDLE};
use crate::{light::Light, material::StandardMaterial, render_graph::PBR_PIPELINE_HANDLE};
use bevy_asset::Handle;
use bevy_ecs::bundle::Bundle;
use bevy_render::{
Expand Down Expand Up @@ -27,7 +27,7 @@ impl Default for PbrBundle {
fn default() -> Self {
Self {
render_pipelines: RenderPipelines::from_pipelines(vec![RenderPipeline::new(
FORWARD_PIPELINE_HANDLE.typed(),
PBR_PIPELINE_HANDLE.typed(),
)]),
mesh: Default::default(),
visible: Default::default(),
Expand Down
4 changes: 2 additions & 2 deletions crates/bevy_pbr/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -42,9 +42,9 @@ impl Plugin for PbrPlugin {
materials.set_untracked(
Handle::<StandardMaterial>::default(),
StandardMaterial {
albedo: Color::PINK,
base_color: Color::PINK,
unlit: true,
albedo_texture: None,
..Default::default()
},
);
}
Expand Down
12 changes: 10 additions & 2 deletions crates/bevy_pbr/src/light.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ pub struct Light {
pub color: Color,
pub fov: f32,
pub depth: Range<f32>,
pub intensity: f32,
pub range: f32,
}

impl Default for Light {
Expand All @@ -23,6 +25,8 @@ impl Default for Light {
color: Color::rgb(1.0, 1.0, 1.0),
depth: 0.1..50.0,
fov: f32::to_radians(60.0),
intensity: 200.0,
range: 20.0,
}
}
}
Expand All @@ -48,10 +52,14 @@ impl LightRaw {

let proj = perspective.get_projection_matrix() * global_transform.compute_matrix();
let (x, y, z) = global_transform.translation.into();

// premultiply color by intensity
// we don't use the alpha at all, so no reason to multiply only [0..3]
let color: [f32; 4] = (light.color * light.intensity).into();
LightRaw {
proj: proj.to_cols_array_2d(),
pos: [x, y, z, 1.0],
color: light.color.into(),
pos: [x, y, z, 1.0 / (light.range * light.range)], // pos.w is the attenuation.
color,
}
}
}
Expand Down
39 changes: 33 additions & 6 deletions crates/bevy_pbr/src/material.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,28 @@ use bevy_reflect::TypeUuid;
use bevy_render::{color::Color, renderer::RenderResources, shader::ShaderDefs, texture::Texture};

/// A material with "standard" properties used in PBR lighting
/// Standard property values with pictures here https://google.github.io/filament/Material%20Properties.pdf
#[derive(Debug, RenderResources, ShaderDefs, TypeUuid)]
#[uuid = "dace545e-4bc6-4595-a79d-c224fc694975"]
pub struct StandardMaterial {
pub albedo: Color,
/// Doubles as diffuse albedo for non-metallic, specular for metallic and a mix for everything in between
/// If used together with a base_color_texture, this is factored into the final base color
/// as `base_color * base_color_texture_value`
pub base_color: Color,
#[shader_def]
pub albedo_texture: Option<Handle<Texture>>,
pub base_color_texture: Option<Handle<Texture>>,
/// Linear perceptual roughness, clamped to [0.089, 1.0] in the shader
/// Defaults to minimum of 0.089
/// If used together with a roughness/metallic texture, this is factored into the final base color
/// as `roughness * roughness_texture_value`
pub roughness: f32,
/// From [0.0, 1.0], dielectric to pure metallic
/// If used together with a roughness/metallic texture, this is factored into the final base color
/// as `metallic * metallic_texture_value`
pub metallic: f32,
/// Specular intensity for non-metals on a linear scale of [0.0, 1.0]
/// defaults to 0.5 which is mapped to 4% reflectance in the shader
pub reflectance: f32,
mtsr marked this conversation as resolved.
Show resolved Hide resolved
#[render_resources(ignore)]
#[shader_def]
pub unlit: bool,
Expand All @@ -17,8 +33,19 @@ pub struct StandardMaterial {
impl Default for StandardMaterial {
fn default() -> Self {
StandardMaterial {
albedo: Color::rgb(1.0, 1.0, 1.0),
albedo_texture: None,
base_color: Color::rgb(1.0, 1.0, 1.0),
base_color_texture: None,
// This is the minimum the roughness is clamped to in shader code
// See https://google.github.io/filament/Filament.html#materialsystem/parameterization/
// It's the minimum floating point value that won't be rounded down to 0 in the calculations used.
// Although technically for 32-bit floats, 0.045 could be used.
roughness: 0.089,
// Few materials are purely dielectric or metallic
// This is just a default for mostly-dielectric
metallic: 0.01,
// Minimum real-world reflectance is 2%, most materials between 2-5%
// Expressed in a linear scale and equivalent to 4% reflectance see https://google.github.io/filament/Material%20Properties.pdf
reflectance: 0.5,
unlit: false,
}
}
Expand All @@ -27,7 +54,7 @@ impl Default for StandardMaterial {
impl From<Color> for StandardMaterial {
fn from(color: Color) -> Self {
StandardMaterial {
albedo: color,
base_color: color,
..Default::default()
}
}
Expand All @@ -36,7 +63,7 @@ impl From<Color> for StandardMaterial {
impl From<Handle<Texture>> for StandardMaterial {
fn from(texture: Handle<Texture>) -> Self {
StandardMaterial {
albedo_texture: Some(texture),
base_color_texture: Some(texture),
..Default::default()
}
}
Expand Down
65 changes: 0 additions & 65 deletions crates/bevy_pbr/src/render_graph/forward_pipeline/forward.frag

This file was deleted.

9 changes: 4 additions & 5 deletions crates/bevy_pbr/src/render_graph/mod.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
mod forward_pipeline;
mod lights_node;
mod pbr_pipeline;

use bevy_ecs::world::World;
pub use forward_pipeline::*;
pub use lights_node::*;
pub use pbr_pipeline::*;

/// the names of pbr graph nodes
pub mod node {
Expand Down Expand Up @@ -50,10 +50,9 @@ pub(crate) fn add_pbr_graph(world: &mut World) {
.add_node_edge(node::LIGHTS, base::node::MAIN_PASS)
.unwrap();
}
let forward_pipeline =
build_forward_pipeline(&mut world.get_resource_mut::<Assets<Shader>>().unwrap());
let pipeline = build_pbr_pipeline(&mut world.get_resource_mut::<Assets<Shader>>().unwrap());
let mut pipelines = world
.get_resource_mut::<Assets<PipelineDescriptor>>()
.unwrap();
pipelines.set_untracked(FORWARD_PIPELINE_HANDLE, forward_pipeline);
pipelines.set_untracked(PBR_PIPELINE_HANDLE, pipeline);
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@ use bevy_render::{
texture::TextureFormat,
};

pub const FORWARD_PIPELINE_HANDLE: HandleUntyped =
pub const PBR_PIPELINE_HANDLE: HandleUntyped =
HandleUntyped::weak_from_u64(PipelineDescriptor::TYPE_UUID, 13148362314012771389);

pub(crate) fn build_forward_pipeline(shaders: &mut Assets<Shader>) -> PipelineDescriptor {
pub(crate) fn build_pbr_pipeline(shaders: &mut Assets<Shader>) -> PipelineDescriptor {
PipelineDescriptor {
depth_stencil: Some(DepthStencilState {
format: TextureFormat::Depth32Float,
Expand Down Expand Up @@ -48,11 +48,11 @@ pub(crate) fn build_forward_pipeline(shaders: &mut Assets<Shader>) -> PipelineDe
..PipelineDescriptor::new(ShaderStages {
vertex: shaders.add(Shader::from_glsl(
ShaderStage::Vertex,
include_str!("forward.vert"),
include_str!("pbr.vert"),
)),
fragment: Some(shaders.add(Shader::from_glsl(
ShaderStage::Fragment,
include_str!("forward.frag"),
include_str!("pbr.frag"),
))),
})
}
Expand Down
Loading