From b5c24d6ec83112440f1a807d5ec79241ea8b40fe Mon Sep 17 00:00:00 2001 From: Emil Ernerfeldt Date: Mon, 22 May 2023 21:37:19 +0200 Subject: [PATCH] egui_demo_app: add some native window info --- crates/egui_demo_app/src/backend_panel.rs | 54 +++++++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/crates/egui_demo_app/src/backend_panel.rs b/crates/egui_demo_app/src/backend_panel.rs index 7fc9fbcebbb..288a953d20e 100644 --- a/crates/egui_demo_app/src/backend_panel.rs +++ b/crates/egui_demo_app/src/backend_panel.rs @@ -190,6 +190,11 @@ impl BackendPanel { { frame.drag_window(); } + + ui.button("Native window info (hover me)") + .on_hover_ui(|ui| { + window_info_ui(ui, &frame.info().window_info); + }); } } @@ -284,6 +289,55 @@ impl BackendPanel { } } +#[cfg(not(target_arch = "wasm32"))] +fn window_info_ui(ui: &mut egui::Ui, window_info: &eframe::WindowInfo) { + let eframe::WindowInfo { + position, + fullscreen, + minimized, + maximized, + focused, + size, + monitor_size, + } = window_info; + + egui::Grid::new("window_info_grid") + .num_columns(2) + .show(ui, |ui| { + if let Some(egui::Pos2 { x, y }) = position { + ui.label("Position:"); + ui.monospace(format!("{x:.0}, {y:.0}")); + ui.end_row(); + } + + ui.label("Fullscreen:"); + ui.label(fullscreen.to_string()); + ui.end_row(); + + ui.label("Minimized:"); + ui.label(minimized.to_string()); + ui.end_row(); + + ui.label("Maximized:"); + ui.label(maximized.to_string()); + ui.end_row(); + + ui.label("Focused:"); + ui.label(focused.to_string()); + ui.end_row(); + + ui.label("Window size:"); + ui.monospace(format!("{x:.0} x {y:.0}", x = size.x, y = size.y)); + ui.end_row(); + + if let Some(egui::Vec2 { x, y }) = monitor_size { + ui.label("Monitor size:"); + ui.monospace(format!("{x:.0} x {y:.0}")); + ui.end_row(); + } + }); +} + // ---------------------------------------------------------------------------- #[cfg_attr(feature = "serde", derive(serde::Deserialize, serde::Serialize))]