diff --git a/crates/fj-viewer/src/graphics/renderer.rs b/crates/fj-viewer/src/graphics/renderer.rs index fef7cb783..49c6f38f8 100644 --- a/crates/fj-viewer/src/graphics/renderer.rs +++ b/crates/fj-viewer/src/graphics/renderer.rs @@ -439,20 +439,18 @@ impl Renderer { }) }); - // End the UI frame. We could now handle the output and draw the UI with the backend. - let egui_output = self.gui.context.end_frame(); - let egui_paint_jobs = self.gui.context.tessellate(egui_output.shapes); - - self.paint_and_update_textures( - // - // Note: `scale_factor` can be overridden via `WINIT_X11_SCALE_FACTOR` environment variable, - // see: - // - scale_factor, - &egui_paint_jobs, - &egui_output.textures_delta, - &color_view, + self.gui.draw( + &self.device, + &self.queue, &mut encoder, + &color_view, + egui_wgpu::renderer::ScreenDescriptor { + size_in_pixels: [ + self.surface_config.width, + self.surface_config.height, + ], + pixels_per_point: scale_factor, + }, ); let command_buffer = encoder.finish(); @@ -559,71 +557,3 @@ pub enum DrawError { #[error("Error drawing text: {0}")] Text(String), } - -impl Renderer { - // - // Note: `egui` changed how it handles updating textures on - // the GPU between v0.17.0 & v0.18.0, this means we can't - // use the same approach as original proof-of-concept used. - // - // Unfortunately we can't use the helper function provided - // by `egui` here, as it is tightly integrated with `Painter` - // which assumes it is handling surface creation itself. - // - // Additionally, subsequent code changes significantly - // changed the API but haven't yet been released. - // - // And, to top it all off, the `Painter::paint_and_update_textures()` - // as it currently exists doesn't support a transparent - // clear color, which we rely on to overlay the UI on the - // already rendered model. - // - // So, as an interim measure, this code is a copy of the - // texture update code from . - // - // Update: Added transparency workaround. - // - fn paint_and_update_textures( - &mut self, - pixels_per_point: f32, - clipped_primitives: &[egui::ClippedPrimitive], - textures_delta: &egui::TexturesDelta, - output_view: &wgpu::TextureView, - encoder: &mut wgpu::CommandEncoder, - ) { - let screen_descriptor = egui_wgpu::renderer::ScreenDescriptor { - size_in_pixels: [ - self.surface_config.width, - self.surface_config.height, - ], - pixels_per_point, - }; - - for (id, image_delta) in &textures_delta.set { - self.gui.render_pass.update_texture( - &self.device, - &self.queue, - *id, - image_delta, - ); - } - for id in &textures_delta.free { - self.gui.render_pass.free_texture(id); - } - - self.gui.render_pass.update_buffers( - &self.device, - &self.queue, - clipped_primitives, - &screen_descriptor, - ); - - self.gui.render_pass.execute( - encoder, - output_view, - clipped_primitives, - &screen_descriptor, - None, - ); - } -} diff --git a/crates/fj-viewer/src/gui.rs b/crates/fj-viewer/src/gui.rs index a3cea286a..19898eac7 100644 --- a/crates/fj-viewer/src/gui.rs +++ b/crates/fj-viewer/src/gui.rs @@ -65,6 +65,41 @@ impl Gui { options: Default::default(), } } + + pub fn draw( + &mut self, + device: &wgpu::Device, + queue: &wgpu::Queue, + encoder: &mut wgpu::CommandEncoder, + color_view: &wgpu::TextureView, + screen_descriptor: egui_wgpu::renderer::ScreenDescriptor, + ) { + let egui_output = self.context.end_frame(); + let clipped_primitives = self.context.tessellate(egui_output.shapes); + + for (id, image_delta) in &egui_output.textures_delta.set { + self.render_pass + .update_texture(device, queue, *id, image_delta); + } + for id in &egui_output.textures_delta.free { + self.render_pass.free_texture(id); + } + + self.render_pass.update_buffers( + device, + queue, + &clipped_primitives, + &screen_descriptor, + ); + + self.render_pass.execute( + encoder, + color_view, + &clipped_primitives, + &screen_descriptor, + None, + ); + } } impl std::fmt::Debug for Gui {