From bb0d600a80e509d7f51ab7ba3e89ef89417a2c57 Mon Sep 17 00:00:00 2001 From: Lucas Meurer Date: Thu, 12 Dec 2024 18:18:42 +0100 Subject: [PATCH] Workaround for firefox reporting wrong device pixel ratio --- crates/eframe/src/web/events.rs | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/crates/eframe/src/web/events.rs b/crates/eframe/src/web/events.rs index 414e5be2383..42fcf9f4c0f 100644 --- a/crates/eframe/src/web/events.rs +++ b/crates/eframe/src/web/events.rs @@ -870,7 +870,15 @@ fn get_display_size(resize_observer_entries: &js_sys::Array) -> Result<(u32, u32 let mut dpr = web_sys::window().unwrap().device_pixel_ratio(); let entry: web_sys::ResizeObserverEntry = resize_observer_entries.at(0).dyn_into()?; - if JsValue::from_str("devicePixelContentBoxSize").js_in(entry.as_ref()) { + // TODO(lucasmerlin): This is disabled because of https://github.com/emilk/egui/issues/5246 + // Not only does it break on chrome when moving the window across screens, but it also + // completely breaks in firefox because for some reason firefox reports the devicePixelRatio + // as 2.0 when it should be 1.0. + // The proper fix would probably be to calculate the correct device pixel ratio based on + // the inline_size and the content_rect.width, and use that + // wherever we access window.devicePixelRatio + #[allow(clippy::overly_complex_bool_expr)] + if JsValue::from_str("devicePixelContentBoxSize").js_in(entry.as_ref()) && false { // NOTE: Only this path gives the correct answer for most browsers. // Unfortunately this doesn't work perfectly everywhere. let size: web_sys::ResizeObserverSize =