Remove ThirdPassDrawerPrepared, change from Discard to Store

This commit is contained in:
Isse 2024-01-27 20:52:44 +01:00 committed by Marcel Märtens
parent 1d48bfff31
commit 25c4d65b5d
5 changed files with 43 additions and 61 deletions

View File

@ -324,8 +324,7 @@ impl PlayState for CharSelectionState {
// Bloom (does nothing if bloom is disabled) // Bloom (does nothing if bloom is disabled)
drawer.run_bloom_passes(); drawer.run_bloom_passes();
// PostProcess and UI // PostProcess and UI
let mut third_pass_prepared = drawer.prepare_third_pass(); let mut third_pass = drawer.third_pass();
let mut third_pass = third_pass_prepared.drawer();
third_pass.draw_postprocess(); third_pass.draw_postprocess();
// Draw the UI to the screen. // Draw the UI to the screen.
if let Some(mut ui_drawer) = third_pass.draw_ui() { if let Some(mut ui_drawer) = third_pass.draw_ui() {

View File

@ -468,8 +468,7 @@ impl PlayState for MainMenuState {
fn render(&self, drawer: &mut Drawer<'_>, _: &Settings) { fn render(&self, drawer: &mut Drawer<'_>, _: &Settings) {
// Draw the UI to the screen. // Draw the UI to the screen.
let mut third_pass_prepared = drawer.prepare_third_pass(); let mut third_pass = drawer.third_pass();
let mut third_pass = third_pass_prepared.drawer();
if let Some(mut ui_drawer) = third_pass.draw_ui() { if let Some(mut ui_drawer) = third_pass.draw_ui() {
self.main_menu_ui.render(&mut ui_drawer); self.main_menu_ui.render(&mut ui_drawer);
}; };

View File

@ -233,8 +233,7 @@ impl PlayState for ServerInfoState {
fn render(&self, drawer: &mut Drawer<'_>, _: &Settings) { fn render(&self, drawer: &mut Drawer<'_>, _: &Settings) {
// Draw the UI to the screen. // Draw the UI to the screen.
let mut third_pass = drawer.prepare_third_pass(); let mut third_pass = drawer.third_pass();
let mut third_pass = third_pass.drawer();
if let Some(mut ui_drawer) = third_pass.draw_ui() { if let Some(mut ui_drawer) = third_pass.draw_ui() {
self.ui.render(&mut ui_drawer); self.ui.render(&mut ui_drawer);
}; };

View File

@ -87,6 +87,7 @@ struct RendererBorrow<'frame> {
} }
pub struct Drawer<'frame> { pub struct Drawer<'frame> {
view: wgpu::TextureView,
encoder: Option<ManualOwningScope<'frame, wgpu::CommandEncoder>>, encoder: Option<ManualOwningScope<'frame, wgpu::CommandEncoder>>,
borrow: RendererBorrow<'frame>, borrow: RendererBorrow<'frame>,
surface_texture: Option<wgpu::SurfaceTexture>, surface_texture: Option<wgpu::SurfaceTexture>,
@ -141,7 +142,16 @@ impl<'frame> Drawer<'frame> {
let encoder = let encoder =
ManualOwningScope::start("frame", &mut renderer.profiler, encoder, borrow.device); ManualOwningScope::start("frame", &mut renderer.profiler, encoder, borrow.device);
// Create a view to the surface texture.
let view = surface_texture
.texture
.create_view(&wgpu::TextureViewDescriptor {
label: Some("Surface texture view"),
..Default::default()
});
Self { Self {
view,
encoder: Some(encoder), encoder: Some(encoder),
borrow, borrow,
surface_texture: Some(surface_texture), surface_texture: Some(surface_texture),
@ -341,7 +351,7 @@ impl<'frame> Drawer<'frame> {
view: &self.borrow.views.tgt_depth, view: &self.borrow.views.tgt_depth,
depth_ops: Some(wgpu::Operations { depth_ops: Some(wgpu::Operations {
load: wgpu::LoadOp::Load, load: wgpu::LoadOp::Load,
store: wgpu::StoreOp::Discard, store: wgpu::StoreOp::Store,
}), }),
stencil_ops: None, stencil_ops: None,
}), }),
@ -502,18 +512,37 @@ impl<'frame> Drawer<'frame> {
/// ///
/// Note, this automatically calls the internal `run_ui_premultiply_passes` /// Note, this automatically calls the internal `run_ui_premultiply_passes`
/// to complete any pending image uploads for the UI. /// to complete any pending image uploads for the UI.
pub fn prepare_third_pass(&mut self) -> ThirdPassDrawerPrepared<'_, 'frame> { pub fn third_pass<'a>(&'a mut self) -> ThirdPassDrawer<'a> {
self.run_ui_premultiply_passes(); self.run_ui_premultiply_passes();
let encoder = self.encoder.as_mut().unwrap();
let device = self.borrow.device;
let mut render_pass =
encoder.scoped_render_pass("third_pass", device, &wgpu::RenderPassDescriptor {
label: Some("third pass (postprocess + ui)"),
color_attachments: &[Some(wgpu::RenderPassColorAttachment {
// If a screenshot was requested render to that as an intermediate texture
// instead
view: self
.taking_screenshot
.as_ref()
.map_or(&self.view, |s| s.texture_view()),
resolve_target: None,
ops: wgpu::Operations {
load: wgpu::LoadOp::Clear(wgpu::Color::TRANSPARENT),
store: wgpu::StoreOp::Store,
},
})],
depth_stencil_attachment: None,
timestamp_writes: None,
occlusion_query_set: None,
});
// Create a view to the surface texture. render_pass.set_bind_group(0, &self.globals.bind_group, &[]);
let view = self.surface_texture.as_ref().unwrap().texture.create_view(
&wgpu::TextureViewDescriptor {
label: Some("Surface texture view"),
..Default::default()
},
);
ThirdPassDrawerPrepared { view, drawer: self } ThirdPassDrawer {
render_pass,
borrow: &self.borrow,
}
} }
#[cfg(feature = "egui-ui")] #[cfg(feature = "egui-ui")]
@ -1312,49 +1341,6 @@ impl<'pass_ref, 'pass: 'pass_ref> TrailDrawer<'pass_ref, 'pass> {
} }
} }
/// Third pass drawer intermediate representation in order to store
/// the surface texture view (in case it's used).
pub struct ThirdPassDrawerPrepared<'pass, 'drawer> {
/// The texture view to render to.
view: wgpu::TextureView,
drawer: &'pass mut Drawer<'drawer>,
}
impl<'pass, 'drawer> ThirdPassDrawerPrepared<'pass, 'drawer> {
pub fn drawer(&mut self) -> ThirdPassDrawer {
let encoder = self.drawer.encoder.as_mut().unwrap();
let device = self.drawer.borrow.device;
let mut render_pass =
encoder.scoped_render_pass("third_pass", device, &wgpu::RenderPassDescriptor {
label: Some("third pass (postprocess + ui)"),
color_attachments: &[Some(wgpu::RenderPassColorAttachment {
// If a screenshot was requested render to that as an intermediate texture
// instead
view: self
.drawer
.taking_screenshot
.as_ref()
.map_or(&self.view, |s| s.texture_view()),
resolve_target: None,
ops: wgpu::Operations {
load: wgpu::LoadOp::Clear(wgpu::Color::TRANSPARENT),
store: wgpu::StoreOp::Store,
},
})],
depth_stencil_attachment: None,
timestamp_writes: None,
occlusion_query_set: None,
});
render_pass.set_bind_group(0, &self.drawer.globals.bind_group, &[]);
ThirdPassDrawer {
render_pass,
borrow: &self.drawer.borrow,
}
}
}
/// Third pass: postprocess + ui /// Third pass: postprocess + ui
#[must_use] #[must_use]
pub struct ThirdPassDrawer<'pass> { pub struct ThirdPassDrawer<'pass> {

View File

@ -2146,8 +2146,7 @@ impl PlayState for SessionState {
// PostProcess and UI // PostProcess and UI
{ {
prof_span!("post-process and ui"); prof_span!("post-process and ui");
let mut third_pass_prepared = drawer.prepare_third_pass(); let mut third_pass = drawer.third_pass();
let mut third_pass = third_pass_prepared.drawer();
third_pass.draw_postprocess(); third_pass.draw_postprocess();
// Draw the UI to the screen // Draw the UI to the screen
if let Some(mut ui_drawer) = third_pass.draw_ui() { if let Some(mut ui_drawer) = third_pass.draw_ui() {