From b2f238601f5f4c659c2ee5cf3aa0861184b7ff0f Mon Sep 17 00:00:00 2001 From: Simon Korzunov Date: Sun, 24 Sep 2023 18:37:10 -0400 Subject: [PATCH 1/2] added a window builder hook for more customization --- crates/eframe/src/epi/mod.rs | 25 ++++++++++++++++++++- crates/eframe/src/native/epi_integration.rs | 7 ++++-- crates/eframe/src/native/run.rs | 10 ++++----- 3 files changed, 34 insertions(+), 8 deletions(-) diff --git a/crates/eframe/src/epi/mod.rs b/crates/eframe/src/epi/mod.rs index d45b39cfbdf..0f80a38c7b5 100644 --- a/crates/eframe/src/epi/mod.rs +++ b/crates/eframe/src/epi/mod.rs @@ -28,7 +28,7 @@ use static_assertions::assert_not_impl_any; #[cfg(not(target_arch = "wasm32"))] #[cfg(any(feature = "glow", feature = "wgpu"))] -pub use winit::event_loop::EventLoopBuilder; +pub use winit::{event_loop::EventLoopBuilder, window::WindowBuilder}; /// Hook into the building of an event loop before it is run /// @@ -38,6 +38,14 @@ pub use winit::event_loop::EventLoopBuilder; #[cfg(any(feature = "glow", feature = "wgpu"))] pub type EventLoopBuilderHook = Box)>; +/// Hook into the building of a the native window. +/// +/// You can configure any platform specific details required on top of the default configuration +/// done by `EFrame`. +#[cfg(not(target_arch = "wasm32"))] +#[cfg(any(feature = "glow", feature = "wgpu"))] +pub type WindowBuilderHook = Box WindowBuilder>; + /// This is how your app is created. /// /// You can use the [`CreationContext`] to setup egui, restore state, setup OpenGL things, etc. @@ -397,6 +405,15 @@ pub struct NativeOptions { #[cfg(any(feature = "glow", feature = "wgpu"))] pub event_loop_builder: Option, + /// Hook into the building of a window. + /// + /// Specify a callback here in case you need to make platform specific changes to the + /// window appearance. + /// + /// Note: A [`NativeOptions`] clone will not include any `window_builder` hook. + #[cfg(any(feature = "glow", feature = "wgpu"))] + pub window_builder: Option, + #[cfg(feature = "glow")] /// Needed for cross compiling for VirtualBox VMSVGA driver with OpenGL ES 2.0 and OpenGL 2.1 which doesn't support SRGB texture. /// See . @@ -466,6 +483,9 @@ impl Clone for NativeOptions { #[cfg(any(feature = "glow", feature = "wgpu"))] event_loop_builder: None, // Skip any builder callbacks if cloning + #[cfg(any(feature = "glow", feature = "wgpu"))] + window_builder: None, // Skip any builder callbacks if cloning + #[cfg(feature = "wgpu")] wgpu_options: self.wgpu_options.clone(), @@ -520,6 +540,9 @@ impl Default for NativeOptions { #[cfg(any(feature = "glow", feature = "wgpu"))] event_loop_builder: None, + #[cfg(any(feature = "glow", feature = "wgpu"))] + window_builder: None, + #[cfg(feature = "glow")] shader_version: None, diff --git a/crates/eframe/src/native/epi_integration.rs b/crates/eframe/src/native/epi_integration.rs index 3912410d8bf..e4e1a3f99cf 100644 --- a/crates/eframe/src/native/epi_integration.rs +++ b/crates/eframe/src/native/epi_integration.rs @@ -75,7 +75,7 @@ pub fn read_window_info( pub fn window_builder( event_loop: &EventLoopWindowTarget, title: &str, - native_options: &epi::NativeOptions, + native_options: &mut epi::NativeOptions, window_settings: Option, ) -> winit::window::WindowBuilder { let epi::NativeOptions { @@ -179,7 +179,10 @@ pub fn window_builder( } } - window_builder + match std::mem::take(&mut native_options.window_builder) { + Some(hook) => hook(window_builder), + None => window_builder, + } } pub fn apply_native_options_to_window( diff --git a/crates/eframe/src/native/run.rs b/crates/eframe/src/native/run.rs index 7631cd78486..ff6aff70ca6 100644 --- a/crates/eframe/src/native/run.rs +++ b/crates/eframe/src/native/run.rs @@ -702,7 +702,7 @@ mod glow_integration { event_loop: &EventLoopWindowTarget, storage: Option<&dyn epi::Storage>, title: &str, - native_options: &NativeOptions, + native_options: &mut NativeOptions, ) -> Result<(GlutinWindowContext, glow::Context)> { crate::profile_function!(); @@ -749,7 +749,7 @@ mod glow_integration { event_loop, storage.as_deref(), &self.app_name, - &self.native_options, + &mut self.native_options, )?; let gl = Arc::new(gl); @@ -1184,7 +1184,7 @@ mod wgpu_integration { event_loop: &EventLoopWindowTarget, storage: Option<&dyn epi::Storage>, title: &str, - native_options: &NativeOptions, + native_options: &mut NativeOptions, ) -> std::result::Result { crate::profile_function!(); @@ -1439,7 +1439,7 @@ mod wgpu_integration { event_loop, running.integration.frame.storage(), &self.app_name, - &self.native_options, + &mut self.native_options, )?; self.set_window(window)?; } @@ -1454,7 +1454,7 @@ mod wgpu_integration { event_loop, storage.as_deref(), &self.app_name, - &self.native_options, + &mut self.native_options, )?; self.init_run_state(event_loop, storage, window)?; } From b1c3545bf47bbfbb9c9f33f9f2b5ce3ac3910d14 Mon Sep 17 00:00:00 2001 From: Emil Ernerfeldt Date: Wed, 27 Sep 2023 08:51:09 +0200 Subject: [PATCH 2/2] `EFrame` -> `eframe` --- crates/eframe/src/epi/mod.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/eframe/src/epi/mod.rs b/crates/eframe/src/epi/mod.rs index 0f80a38c7b5..508c1c5545b 100644 --- a/crates/eframe/src/epi/mod.rs +++ b/crates/eframe/src/epi/mod.rs @@ -41,7 +41,7 @@ pub type EventLoopBuilderHook = Box) /// Hook into the building of a the native window. /// /// You can configure any platform specific details required on top of the default configuration -/// done by `EFrame`. +/// done by `eframe`. #[cfg(not(target_arch = "wasm32"))] #[cfg(any(feature = "glow", feature = "wgpu"))] pub type WindowBuilderHook = Box WindowBuilder>;