mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 05:21:31 +11:00
Rename Window::set_inner_size
to Window::request_inner_size
Some systems could resize the window immediately and we'd rather inform the users right away if that was the case, so they could create e.g. EGLSurface without waiting for resize, which is really important for Wayland. Fixes #2868.
This commit is contained in:
parent
42e492cde8
commit
ff0ce9d065
|
@ -8,8 +8,8 @@ And please only add new entries to the top of this list, right below the `# Unre
|
||||||
|
|
||||||
# Unreleased
|
# Unreleased
|
||||||
|
|
||||||
- On X11, fix false positive flagging of key repeats when pressing different keys with no release
|
- **Breaking:** Rename `Window::set_inner_size` to `Window::request_inner_size` and indicate if the size was applied immediately.
|
||||||
between presses.
|
- On X11, fix false positive flagging of key repeats when pressing different keys with no release between presses.
|
||||||
- Implement `PartialOrd` and `Ord` for `KeyCode` and `NativeKeyCode`.
|
- Implement `PartialOrd` and `Ord` for `KeyCode` and `NativeKeyCode`.
|
||||||
- On Web, implement `WindowEvent::Occluded`.
|
- On Web, implement `WindowEvent::Occluded`.
|
||||||
- On Web, fix touch location to be as accurate as mouse position.
|
- On Web, fix touch location to be as accurate as mouse position.
|
||||||
|
|
|
@ -137,13 +137,15 @@ fn main() {
|
||||||
}),
|
}),
|
||||||
"q" => window.request_redraw(),
|
"q" => window.request_redraw(),
|
||||||
"r" => window.set_resizable(state),
|
"r" => window.set_resizable(state),
|
||||||
"s" => window.set_inner_size(match state {
|
"s" => {
|
||||||
|
let _ = window.request_inner_size(match state {
|
||||||
true => PhysicalSize::new(
|
true => PhysicalSize::new(
|
||||||
WINDOW_SIZE.width + 100,
|
WINDOW_SIZE.width + 100,
|
||||||
WINDOW_SIZE.height + 100,
|
WINDOW_SIZE.height + 100,
|
||||||
),
|
),
|
||||||
false => WINDOW_SIZE,
|
false => WINDOW_SIZE,
|
||||||
}),
|
});
|
||||||
|
}
|
||||||
"w" => {
|
"w" => {
|
||||||
if let Size::Physical(size) = WINDOW_SIZE.into() {
|
if let Size::Physical(size) = WINDOW_SIZE.into() {
|
||||||
window
|
window
|
||||||
|
|
|
@ -802,8 +802,8 @@ impl Window {
|
||||||
self.outer_size()
|
self.outer_size()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_inner_size(&self, _size: Size) {
|
pub fn request_inner_size(&self, _size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
warn!("Cannot set window size on Android");
|
Some(self.inner_size())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn outer_size(&self) -> PhysicalSize<u32> {
|
pub fn outer_size(&self) -> PhysicalSize<u32> {
|
||||||
|
|
|
@ -139,8 +139,8 @@ impl Inner {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_inner_size(&self, _size: Size) {
|
pub fn request_inner_size(&self, _size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
warn!("not clear what `Window::set_inner_size` means on iOS");
|
Some(self.inner_size())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_min_inner_size(&self, _dimensions: Option<Size>) {
|
pub fn set_min_inner_size(&self, _dimensions: Option<Size>) {
|
||||||
|
|
|
@ -367,8 +367,8 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size(&self, size: Size) {
|
pub fn request_inner_size(&self, size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
x11_or_wayland!(match self; Window(w) => w.set_inner_size(size))
|
x11_or_wayland!(match self; Window(w) => w.request_inner_size(size))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
|
@ -292,13 +292,14 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size(&self, size: Size) {
|
pub fn request_inner_size(&self, size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
// TODO should we issue the resize event? I don't think other platforms do so.
|
|
||||||
let mut window_state = self.window_state.lock().unwrap();
|
let mut window_state = self.window_state.lock().unwrap();
|
||||||
let scale_factor = window_state.scale_factor();
|
let scale_factor = window_state.scale_factor();
|
||||||
window_state.resize(size.to_logical::<u32>(scale_factor));
|
window_state.resize(size.to_logical::<u32>(scale_factor));
|
||||||
|
|
||||||
self.request_redraw();
|
self.request_redraw();
|
||||||
|
|
||||||
|
Some(window_state.inner_size().to_physical(scale_factor))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Set the minimum inner size for the window.
|
/// Set the minimum inner size for the window.
|
||||||
|
|
|
@ -419,7 +419,7 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
});
|
});
|
||||||
|
|
||||||
if new_inner_size != old_inner_size {
|
if new_inner_size != old_inner_size {
|
||||||
window.set_inner_size_physical(
|
window.request_inner_size_physical(
|
||||||
new_inner_size.width,
|
new_inner_size.width,
|
||||||
new_inner_size.height,
|
new_inner_size.height,
|
||||||
);
|
);
|
||||||
|
@ -443,7 +443,7 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
// When this finally happens, the event will not be synthetic.
|
// When this finally happens, the event will not be synthetic.
|
||||||
shared_state_lock.dpi_adjusted = None;
|
shared_state_lock.dpi_adjusted = None;
|
||||||
} else {
|
} else {
|
||||||
window.set_inner_size_physical(adjusted_size.0, adjusted_size.1);
|
window.request_inner_size_physical(adjusted_size.0, adjusted_size.1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1232,8 +1232,9 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
|
|
||||||
if new_inner_size != old_inner_size {
|
if new_inner_size != old_inner_size {
|
||||||
let (new_width, new_height) = new_inner_size.into();
|
let (new_width, new_height) = new_inner_size.into();
|
||||||
window
|
window.request_inner_size_physical(
|
||||||
.set_inner_size_physical(new_width, new_height);
|
new_width, new_height,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1143,7 +1143,7 @@ impl UnownedWindow {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn set_inner_size_physical(&self, width: u32, height: u32) {
|
pub(crate) fn request_inner_size_physical(&self, width: u32, height: u32) {
|
||||||
unsafe {
|
unsafe {
|
||||||
(self.xconn.xlib.XResizeWindow)(
|
(self.xconn.xlib.XResizeWindow)(
|
||||||
self.xconn.display,
|
self.xconn.display,
|
||||||
|
@ -1157,7 +1157,7 @@ impl UnownedWindow {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size(&self, size: Size) {
|
pub fn request_inner_size(&self, size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
let scale_factor = self.scale_factor();
|
let scale_factor = self.scale_factor();
|
||||||
let size = size.to_physical::<u32>(scale_factor).into();
|
let size = size.to_physical::<u32>(scale_factor).into();
|
||||||
if !self.shared_state_lock().is_resizable {
|
if !self.shared_state_lock().is_resizable {
|
||||||
|
@ -1167,7 +1167,9 @@ impl UnownedWindow {
|
||||||
})
|
})
|
||||||
.expect("Failed to call `XSetWMNormalHints`");
|
.expect("Failed to call `XSetWMNormalHints`");
|
||||||
}
|
}
|
||||||
self.set_inner_size_physical(size.0, size.1);
|
self.request_inner_size_physical(size.0, size.1);
|
||||||
|
|
||||||
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
fn update_normal_hints<F>(&self, callback: F) -> Result<(), XError>
|
fn update_normal_hints<F>(&self, callback: F) -> Result<(), XError>
|
||||||
|
|
|
@ -608,9 +608,10 @@ impl WinitWindow {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size(&self, size: Size) {
|
pub fn request_inner_size(&self, size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
let scale_factor = self.scale_factor();
|
let scale_factor = self.scale_factor();
|
||||||
util::set_content_size_sync(self, size.to_logical(scale_factor));
|
util::set_content_size_sync(self, size.to_logical(scale_factor));
|
||||||
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_min_inner_size(&self, dimensions: Option<Size>) {
|
pub fn set_min_inner_size(&self, dimensions: Option<Size>) {
|
||||||
|
|
|
@ -209,11 +209,12 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size(&self, size: Size) {
|
pub fn request_inner_size(&self, size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
let (w, h): (u32, u32) = size.to_physical::<u32>(self.scale_factor()).into();
|
let (w, h): (u32, u32) = size.to_physical::<u32>(self.scale_factor()).into();
|
||||||
self.window_socket
|
self.window_socket
|
||||||
.write(format!("S,{w},{h}").as_bytes())
|
.write(format!("S,{w},{h}").as_bytes())
|
||||||
.expect("failed to set size");
|
.expect("failed to set size");
|
||||||
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
|
@ -148,12 +148,14 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size(&self, size: Size) {
|
pub fn request_inner_size(&self, size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
self.inner.dispatch(move |inner| {
|
self.inner.dispatch(move |inner| {
|
||||||
let size = size.to_logical(inner.scale_factor());
|
let size = size.to_logical(inner.scale_factor());
|
||||||
let canvas = inner.canvas.borrow();
|
let canvas = inner.canvas.borrow();
|
||||||
backend::set_canvas_size(canvas.window(), canvas.raw(), size);
|
backend::set_canvas_size(canvas.window(), canvas.raw(), size);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
|
@ -210,7 +210,7 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size(&self, size: Size) {
|
pub fn request_inner_size(&self, size: Size) -> Option<PhysicalSize<u32>> {
|
||||||
let scale_factor = self.scale_factor();
|
let scale_factor = self.scale_factor();
|
||||||
let physical_size = size.to_physical::<u32>(scale_factor);
|
let physical_size = size.to_physical::<u32>(scale_factor);
|
||||||
|
|
||||||
|
@ -225,6 +225,7 @@ impl Window {
|
||||||
|
|
||||||
let window_flags = self.window_state_lock().window_flags;
|
let window_flags = self.window_state_lock().window_flags;
|
||||||
window_flags.set_size(self.hwnd(), physical_size);
|
window_flags.set_size(self.hwnd(), physical_size);
|
||||||
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -232,7 +233,7 @@ impl Window {
|
||||||
self.window_state_lock().min_size = size;
|
self.window_state_lock().min_size = size;
|
||||||
// Make windows re-check the window size bounds.
|
// Make windows re-check the window size bounds.
|
||||||
let size = self.inner_size();
|
let size = self.inner_size();
|
||||||
self.set_inner_size(size.into());
|
self.request_inner_size(size.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -240,7 +241,7 @@ impl Window {
|
||||||
self.window_state_lock().max_size = size;
|
self.window_state_lock().max_size = size;
|
||||||
// Make windows re-check the window size bounds.
|
// Make windows re-check the window size bounds.
|
||||||
let size = self.inner_size();
|
let size = self.inner_size();
|
||||||
self.set_inner_size(size.into());
|
self.request_inner_size(size.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -1051,11 +1052,11 @@ impl<'a, T: 'static> InitData<'a, T> {
|
||||||
.min_inner_size
|
.min_inner_size
|
||||||
.unwrap_or_else(|| PhysicalSize::new(0, 0).into());
|
.unwrap_or_else(|| PhysicalSize::new(0, 0).into());
|
||||||
let clamped_size = Size::clamp(size, min_size, max_size, win.scale_factor());
|
let clamped_size = Size::clamp(size, min_size, max_size, win.scale_factor());
|
||||||
win.set_inner_size(clamped_size);
|
win.request_inner_size(clamped_size);
|
||||||
|
|
||||||
if attributes.maximized {
|
if attributes.maximized {
|
||||||
// Need to set MAXIMIZED after setting `inner_size` as
|
// Need to set MAXIMIZED after setting `inner_size` as
|
||||||
// `Window::set_inner_size` changes MAXIMIZED to false.
|
// `Window::request_inner_size` changes MAXIMIZED to false.
|
||||||
win.set_maximized(true);
|
win.set_maximized(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -188,7 +188,7 @@ impl WindowBuilder {
|
||||||
///
|
///
|
||||||
/// If this is not set, some platform-specific dimensions will be used.
|
/// If this is not set, some platform-specific dimensions will be used.
|
||||||
///
|
///
|
||||||
/// See [`Window::set_inner_size`] for details.
|
/// See [`Window::request_inner_size`] for details.
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn with_inner_size<S: Into<Size>>(mut self, size: S) -> Self {
|
pub fn with_inner_size<S: Into<Size>>(mut self, size: S) -> Self {
|
||||||
self.window.inner_size = Some(size.into());
|
self.window.inner_size = Some(size.into());
|
||||||
|
@ -652,10 +652,21 @@ impl Window {
|
||||||
self.window.inner_size()
|
self.window.inner_size()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Modifies the inner size of the window.
|
/// Request the new size for the window.
|
||||||
|
///
|
||||||
|
/// On platforms where the size is entirely controlled by the user the
|
||||||
|
/// applied size will be returned immediately, resize event in such case
|
||||||
|
/// may not be generated.
|
||||||
|
///
|
||||||
|
/// On platforms where resizing is disallowed by the windowing system, the current
|
||||||
|
/// inner size is returned immidiatelly, and the user one is ignored.
|
||||||
|
///
|
||||||
|
/// When `None` is returned, it means that the request went to the display system,
|
||||||
|
/// and the actual size will be delivered later with the [`WindowEvent::Resized`].
|
||||||
///
|
///
|
||||||
/// See [`Window::inner_size`] for more information about the values.
|
/// See [`Window::inner_size`] for more information about the values.
|
||||||
/// This automatically un-maximizes the window if it's maximized.
|
///
|
||||||
|
/// The request could automatically un-maximize the window if it's maximized.
|
||||||
///
|
///
|
||||||
/// ```no_run
|
/// ```no_run
|
||||||
/// # use winit::dpi::{LogicalSize, PhysicalSize};
|
/// # use winit::dpi::{LogicalSize, PhysicalSize};
|
||||||
|
@ -664,19 +675,21 @@ impl Window {
|
||||||
/// # let mut event_loop = EventLoop::new();
|
/// # let mut event_loop = EventLoop::new();
|
||||||
/// # let window = Window::new(&event_loop).unwrap();
|
/// # let window = Window::new(&event_loop).unwrap();
|
||||||
/// // Specify the size in logical dimensions like this:
|
/// // Specify the size in logical dimensions like this:
|
||||||
/// window.set_inner_size(LogicalSize::new(400.0, 200.0));
|
/// let _ = window.request_inner_size(LogicalSize::new(400.0, 200.0));
|
||||||
///
|
///
|
||||||
/// // Or specify the size in physical dimensions like this:
|
/// // Or specify the size in physical dimensions like this:
|
||||||
/// window.set_inner_size(PhysicalSize::new(400, 200));
|
/// let _ = window.request_inner_size(PhysicalSize::new(400, 200));
|
||||||
/// ```
|
/// ```
|
||||||
///
|
///
|
||||||
/// ## Platform-specific
|
/// ## Platform-specific
|
||||||
///
|
///
|
||||||
/// - **iOS / Android:** Unsupported.
|
|
||||||
/// - **Web:** Sets the size of the canvas element.
|
/// - **Web:** Sets the size of the canvas element.
|
||||||
|
///
|
||||||
|
/// [`WindowEvent::Resized`]: crate::event::WindowEvent::Resized.
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size<S: Into<Size>>(&self, size: S) {
|
#[must_use]
|
||||||
self.window.set_inner_size(size.into())
|
pub fn request_inner_size<S: Into<Size>>(&self, size: S) -> Option<PhysicalSize<u32>> {
|
||||||
|
self.window.request_inner_size(size.into())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the physical size of the entire window.
|
/// Returns the physical size of the entire window.
|
||||||
|
@ -827,7 +840,7 @@ impl Window {
|
||||||
///
|
///
|
||||||
/// Note that making the window unresizable doesn't exempt you from handling [`WindowEvent::Resized`], as that
|
/// Note that making the window unresizable doesn't exempt you from handling [`WindowEvent::Resized`], as that
|
||||||
/// event can still be triggered by DPI scaling, entering fullscreen mode, etc. Also, the
|
/// event can still be triggered by DPI scaling, entering fullscreen mode, etc. Also, the
|
||||||
/// window could still be resized by calling [`Window::set_inner_size`].
|
/// window could still be resized by calling [`Window::request_inner_size`].
|
||||||
///
|
///
|
||||||
/// ## Platform-specific
|
/// ## Platform-specific
|
||||||
///
|
///
|
||||||
|
|
Loading…
Reference in a new issue