mirror of
https://github.com/gfx-rs/wgpu.git
synced 2024-11-21 14:23:32 +00:00
Fix iOS crash: don't set autoresizing mask (#6535)
This commit is contained in:
parent
278620be26
commit
4681f4ffba
@ -139,6 +139,10 @@ By @ErichDonGubler in [#6456](https://github.com/gfx-rs/wgpu/pull/6456), [#6148]
|
||||
|
||||
- Fix surface capabilities being advertised when its query failed. By @wumpf in [#6510](https://github.com/gfx-rs/wgpu/pull/6510)
|
||||
|
||||
### Metal
|
||||
|
||||
- Fix surface creation crashing on iOS. By @mockersf in [#6535](https://github.com/gfx-rs/wgpu/pull/6535)
|
||||
|
||||
|
||||
## 23.0.0 (2024-10-25)
|
||||
|
||||
|
@ -1,6 +1,5 @@
|
||||
#![allow(clippy::let_unit_value)] // `let () =` being used to constrain result type
|
||||
|
||||
use std::ffi::c_uint;
|
||||
use std::mem::ManuallyDrop;
|
||||
use std::ptr::NonNull;
|
||||
use std::sync::Once;
|
||||
@ -207,23 +206,26 @@ impl super::Surface {
|
||||
let new_layer: *mut Object = msg_send![class!(CAMetalLayer), new];
|
||||
let () = msg_send![root_layer, addSublayer: new_layer];
|
||||
|
||||
// Automatically resize the sublayer's frame to match the
|
||||
// superlayer's bounds.
|
||||
//
|
||||
// Note that there is a somewhat hidden design decision in this:
|
||||
// We define the `width` and `height` in `configure` to control
|
||||
// the `drawableSize` of the layer, while `bounds` and `frame` are
|
||||
// outside of the user's direct control - instead, though, they
|
||||
// can control the size of the view (or root layer), and get the
|
||||
// desired effect that way.
|
||||
//
|
||||
// We _could_ also let `configure` set the `bounds` size, however
|
||||
// that would be inconsistent with using the root layer directly
|
||||
// (as we may do, see above).
|
||||
let width_sizable = 1 << 1; // kCALayerWidthSizable
|
||||
let height_sizable = 1 << 4; // kCALayerHeightSizable
|
||||
let mask: c_uint = width_sizable | height_sizable;
|
||||
let () = msg_send![new_layer, setAutoresizingMask: mask];
|
||||
#[cfg(target_os = "macos")]
|
||||
{
|
||||
// Automatically resize the sublayer's frame to match the
|
||||
// superlayer's bounds.
|
||||
//
|
||||
// Note that there is a somewhat hidden design decision in this:
|
||||
// We define the `width` and `height` in `configure` to control
|
||||
// the `drawableSize` of the layer, while `bounds` and `frame` are
|
||||
// outside of the user's direct control - instead, though, they
|
||||
// can control the size of the view (or root layer), and get the
|
||||
// desired effect that way.
|
||||
//
|
||||
// We _could_ also let `configure` set the `bounds` size, however
|
||||
// that would be inconsistent with using the root layer directly
|
||||
// (as we may do, see above).
|
||||
let width_sizable = 1 << 1; // kCALayerWidthSizable
|
||||
let height_sizable = 1 << 4; // kCALayerHeightSizable
|
||||
let mask: std::ffi::c_uint = width_sizable | height_sizable;
|
||||
let () = msg_send![new_layer, setAutoresizingMask: mask];
|
||||
}
|
||||
|
||||
// Specify the relative size that the auto resizing mask above
|
||||
// will keep (i.e. tell it to fill out its superlayer).
|
||||
|
Loading…
Reference in New Issue
Block a user