From cb0a085968252dc4f0178a40fb5ba88d8530bb31 Mon Sep 17 00:00:00 2001 From: Francesca Plebani Date: Fri, 30 Nov 2018 16:19:50 -0500 Subject: [PATCH] X11: WindowBuilder min/max size accounts for DPI (#729) --- CHANGELOG.md | 1 + src/platform/linux/x11/window.rs | 6 ++++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c756381c..3b2f2e78 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,7 @@ - Derive `Ord` and `PartialOrd` for `VirtualKeyCode` enum. - On Windows, fix issue where hovering or dropping a non file item would create a panic. - On Wayland, fix resizing and DPI calculation when a `wl_output` is removed without sending a `leave` event to the `wl_surface`, such as disconnecting a monitor from a laptop. +- On X11, `WindowBuilder::with_min_dimensions` and `WindowBuilder::with_max_dimensions` now correctly account for DPI. # Version 0.18.0 (2018-11-07) diff --git a/src/platform/linux/x11/window.rs b/src/platform/linux/x11/window.rs index 6e73aca0..8a5f711e 100644 --- a/src/platform/linux/x11/window.rs +++ b/src/platform/linux/x11/window.rs @@ -278,8 +278,10 @@ impl UnownedWindow { // set size hints { - let mut min_dimensions = window_attrs.min_dimensions; - let mut max_dimensions = window_attrs.max_dimensions; + let mut min_dimensions = window_attrs.min_dimensions + .map(|size| size.to_physical(dpi_factor)); + let mut max_dimensions = window_attrs.max_dimensions + .map(|size| size.to_physical(dpi_factor)); if !window_attrs.resizable { if util::wm_name_is_one_of(&["Xfwm4"]) { warn!("To avoid a WM bug, disabling resizing has no effect on Xfwm4");