From 72fc6a74ec3da62355bacf860950e03b42dbd11b Mon Sep 17 00:00:00 2001 From: Kirill Chibisov Date: Fri, 1 Nov 2019 03:45:45 +0300 Subject: [PATCH] on Wayland, drop resize events equal to the current window size (#1249) * on Wayland, drop resize events equal to the current window size * Add changelog entry --- CHANGELOG.md | 1 + src/platform_impl/linux/wayland/event_loop.rs | 25 ++++++++++++------- 2 files changed, 17 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d30af4f7..8dc52443 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -43,6 +43,7 @@ - This is because some platforms cannot run the event loop outside the main thread. Preventing this reduces the potential for cross-platform compatibility gotchyas. - On Windows and Linux X11/Wayland, add platform-specific functions for creating an `EventLoop` outside the main thread. +- On Wayland, drop resize events identical to the current window size. # 0.20.0 Alpha 3 (2019-08-14) diff --git a/src/platform_impl/linux/wayland/event_loop.rs b/src/platform_impl/linux/wayland/event_loop.rs index ca922c5f..3e04137e 100644 --- a/src/platform_impl/linux/wayland/event_loop.rs +++ b/src/platform_impl/linux/wayland/event_loop.rs @@ -673,15 +673,22 @@ impl EventLoop { wid, frame| { if let Some(frame) = frame { - if let Some((w, h)) = newsize { - frame.resize(w, h); - frame.refresh(); - let logical_size = crate::dpi::LogicalSize::new(w as f64, h as f64); - sink.send_window_event( - crate::event::WindowEvent::Resized(logical_size), - wid, - ); - *size = (w, h); + if let Some(newsize) = newsize { + // Drop resize events equaled to the current size + if newsize != *size { + let (w, h) = newsize; + frame.resize(w, h); + frame.refresh(); + let logical_size = crate::dpi::LogicalSize::new(w as f64, h as f64); + sink.send_window_event( + crate::event::WindowEvent::Resized(logical_size), + wid, + ); + *size = (w, h); + } else { + // Refresh csd, etc, otherwise + frame.refresh(); + } } else if frame_refresh { frame.refresh(); if !refresh {