On macOS, set resize increments only for live resize

Closes #2684 for macOS.
This commit is contained in:
Kirill Chibisov 2023-02-15 03:32:55 +03:00 committed by GitHub
parent 265152355e
commit 82df9531f4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 46 additions and 16 deletions

View file

@ -9,6 +9,7 @@ And please only add new entries to the top of this list, right below the `# Unre
# Unreleased # Unreleased
- Implement `HasRawDisplayHandle` for `EventLoop`. - Implement `HasRawDisplayHandle` for `EventLoop`.
- On macOS, set resize increments only for live resizes.
# 0.28.1 # 0.28.1

View file

@ -160,6 +160,9 @@ pub struct SharedState {
save_presentation_opts: Option<NSApplicationPresentationOptions>, save_presentation_opts: Option<NSApplicationPresentationOptions>,
pub current_theme: Option<Theme>, pub current_theme: Option<Theme>,
/// The current resize incerments for the window content.
pub(crate) resize_increments: NSSize,
/// The state of the `Option` as `Alt`. /// The state of the `Option` as `Alt`.
pub(crate) option_as_alt: OptionAsAlt, pub(crate) option_as_alt: OptionAsAlt,
} }
@ -301,6 +304,16 @@ impl WinitWindow {
}; };
this.map(|mut this| { this.map(|mut this| {
let resize_increments = match attrs
.resize_increments
.map(|i| i.to_logical::<f64>(this.scale_factor()))
{
Some(LogicalSize { width, height }) if width >= 1. && height >= 1. => {
NSSize::new(width, height)
}
_ => NSSize::new(1., 1.),
};
// Properly initialize the window's variables // Properly initialize the window's variables
// //
// Ideally this should be done in an `init` method, // Ideally this should be done in an `init` method,
@ -308,6 +321,7 @@ impl WinitWindow {
let state = SharedState { let state = SharedState {
resizable: attrs.resizable, resizable: attrs.resizable,
maximized: attrs.maximized, maximized: attrs.maximized,
resize_increments,
..Default::default() ..Default::default()
}; };
Ivar::write(&mut this.shared_state, Box::new(Mutex::new(state))); Ivar::write(&mut this.shared_state, Box::new(Mutex::new(state)));
@ -353,19 +367,6 @@ impl WinitWindow {
} }
} }
if let Some(increments) = attrs.resize_increments {
let increments = increments.to_logical(this.scale_factor());
let (w, h) = (increments.width, increments.height);
if w >= 1.0 && h >= 1.0 {
let size = NSSize::new(w, h);
// It was concluded (#2411) that there is never a use-case for
// "outer" resize increments, hence we set "inner" ones here.
// ("outer" in macOS being just resizeIncrements, and "inner" - contentResizeIncrements)
// This is consistent with X11 size hints behavior
this.setContentResizeIncrements(size);
}
}
if !pl_attrs.has_shadow { if !pl_attrs.has_shadow {
this.setHasShadow(false); this.setHasShadow(false);
} }
@ -648,7 +649,9 @@ impl WinitWindow {
} }
pub fn resize_increments(&self) -> Option<PhysicalSize<u32>> { pub fn resize_increments(&self) -> Option<PhysicalSize<u32>> {
let increments = self.contentResizeIncrements(); let increments = self
.lock_shared_state("set_resize_increments")
.resize_increments;
let (w, h) = (increments.width, increments.height); let (w, h) = (increments.width, increments.height);
if w > 1.0 || h > 1.0 { if w > 1.0 || h > 1.0 {
Some(LogicalSize::new(w, h).to_physical(self.scale_factor())) Some(LogicalSize::new(w, h).to_physical(self.scale_factor()))
@ -658,12 +661,21 @@ impl WinitWindow {
} }
pub fn set_resize_increments(&self, increments: Option<Size>) { pub fn set_resize_increments(&self, increments: Option<Size>) {
let size = increments // XXX the resize increments are only used during live resizes.
let mut shared_state_lock = self.lock_shared_state("set_resize_increments");
shared_state_lock.resize_increments = increments
.map(|increments| { .map(|increments| {
let logical = increments.to_logical::<f64>(self.scale_factor()); let logical = increments.to_logical::<f64>(self.scale_factor());
NSSize::new(logical.width.max(1.0), logical.height.max(1.0)) NSSize::new(logical.width.max(1.0), logical.height.max(1.0))
}) })
.unwrap_or_else(|| NSSize::new(1.0, 1.0)); .unwrap_or_else(|| NSSize::new(1.0, 1.0));
}
pub(crate) fn set_resize_increments_inner(&self, size: NSSize) {
// It was concluded (#2411) that there is never a use-case for
// "outer" resize increments, hence we set "inner" ones here.
// ("outer" in macOS being just resizeIncrements, and "inner" - contentResizeIncrements)
// This is consistent with X11 size hints behavior
self.setContentResizeIncrements(size); self.setContentResizeIncrements(size);
} }

View file

@ -3,7 +3,7 @@
use std::ptr; use std::ptr;
use objc2::declare::{Ivar, IvarDrop}; use objc2::declare::{Ivar, IvarDrop};
use objc2::foundation::{NSArray, NSObject, NSString}; use objc2::foundation::{NSArray, NSObject, NSSize, NSString};
use objc2::rc::{autoreleasepool, Id, Shared}; use objc2::rc::{autoreleasepool, Id, Shared};
use objc2::runtime::Object; use objc2::runtime::Object;
use objc2::{class, declare_class, msg_send, msg_send_id, sel, ClassType}; use objc2::{class, declare_class, msg_send, msg_send_id, sel, ClassType};
@ -117,6 +117,23 @@ declare_class!(
self.emit_move_event(); self.emit_move_event();
} }
#[sel(windowWillStartLiveResize:)]
fn window_will_start_live_resize(&mut self, _: Option<&Object>) {
trace_scope!("windowWillStartLiveResize:");
let increments = self
.window
.lock_shared_state("window_will_enter_fullscreen")
.resize_increments;
self.window.set_resize_increments_inner(increments);
}
#[sel(windowDidEndLiveResize:)]
fn window_did_end_live_resize(&mut self, _: Option<&Object>) {
trace_scope!("windowDidEndLiveResize:");
self.window.set_resize_increments_inner(NSSize::new(1., 1.));
}
// This won't be triggered if the move was part of a resize. // This won't be triggered if the move was part of a resize.
#[sel(windowDidMove:)] #[sel(windowDidMove:)]
fn window_did_move(&mut self, _: Option<&Object>) { fn window_did_move(&mut self, _: Option<&Object>) {