From 83ab27b5cbb20de79e532687a342a5f4036e3046 Mon Sep 17 00:00:00 2001 From: Richard Date: Thu, 17 Mar 2022 00:59:35 -0300 Subject: Add graphics information to `iced_winit` --- winit/src/application.rs | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) (limited to 'winit/src') diff --git a/winit/src/application.rs b/winit/src/application.rs index f5a58f2f..9d65d769 100644 --- a/winit/src/application.rs +++ b/winit/src/application.rs @@ -167,17 +167,18 @@ where let mut clipboard = Clipboard::connect(&window); + let (compositor, renderer) = C::new(compositor_settings, Some(&window))?; + run_command( init_command, &mut runtime, &mut clipboard, &mut proxy, &window, + &compositor.get_information(), ); runtime.track(subscription); - let (compositor, renderer) = C::new(compositor_settings, Some(&window))?; - let (mut sender, receiver) = mpsc::unbounded(); let mut instance = Box::pin(run_instance::( @@ -262,6 +263,8 @@ async fn run_instance( physical_size.height, ); + let graphics_info = compositor.get_information(); + let mut user_interface = ManuallyDrop::new(build_user_interface( &mut application, user_interface::Cache::default(), @@ -317,6 +320,7 @@ async fn run_instance( &mut debug, &mut messages, &window, + &graphics_info, ); // Update window @@ -516,6 +520,7 @@ pub fn update( debug: &mut Debug, messages: &mut Vec, window: &winit::window::Window, + graphics_info: &window::GraphicsInformation, ) { for message in messages.drain(..) { debug.log_message(&message); @@ -524,7 +529,7 @@ pub fn update( let command = runtime.enter(|| application.update(message)); debug.update_finished(); - run_command(command, runtime, clipboard, proxy, window); + run_command(command, runtime, clipboard, proxy, window, graphics_info); } let subscription = application.subscription(); @@ -538,6 +543,7 @@ pub fn run_command( clipboard: &mut Clipboard, proxy: &mut winit::event_loop::EventLoopProxy, window: &winit::window::Window, + graphics_info: &window::GraphicsInformation, ) { use iced_native::command; use iced_native::system; @@ -591,6 +597,8 @@ pub fn run_command( cpu_brand: cpu.brand().into(), cpu_cores: system.physical_core_count(), memory_total: system.total_memory(), + graphics_adapter: graphics_info.adapter.clone(), + graphics_backend: graphics_info.backend.clone(), }; Some(information) -- cgit