qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v2] ui/cocoa: Fix window clipping on macOS 14


From: Akihiko Odaki
Subject: Re: [PATCH v2] ui/cocoa: Fix window clipping on macOS 14
Date: Sat, 24 Feb 2024 23:19:29 +0900
User-agent: Mozilla Thunderbird

On 2024/02/24 23:06, David Parsons wrote:
macOS Sonoma changes the NSView.clipsToBounds to false by default
where it was true in earlier version of macOS. This causes the window
contents to be occluded by the frame at the top of the window. This
fixes the issue by conditionally compiling the clipping on Sonoma to
true. NSView only exposes the clipToBounds in macOS 14 and so has
to be fixed via conditional compilation.

Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1994
Signed-off-by: David Parsons <dave@daveparsons.net>

Reviewed-by: Akihiko Odaki <akihiko.odaki@daynix.com>

---
  ui/cocoa.m | 7 +++++++
  1 file changed, 7 insertions(+)

diff --git a/ui/cocoa.m b/ui/cocoa.m
index eb99064bee..bbf9704b8c 100644
--- a/ui/cocoa.m
+++ b/ui/cocoa.m
@@ -54,6 +54,10 @@
  #define MAC_OS_X_VERSION_10_13 101300
  #endif
+#ifndef MAC_OS_VERSION_14_0
+#define MAC_OS_VERSION_14_0 140000
+#endif
+
  /* 10.14 deprecates NSOnState and NSOffState in favor of
   * NSControlStateValueOn/Off, which were introduced in 10.13.
   * Define for older versions
@@ -365,6 +369,9 @@ - (id)initWithFrame:(NSRect)frameRect
          screen.width = frameRect.size.width;
          screen.height = frameRect.size.height;
          kbd = qkbd_state_init(dcl.con);
+#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_VERSION_14_0
+        [self setClipsToBounds:YES];
+#endif
}
      return self;



reply via email to

[Prev in Thread] Current Thread [Next in Thread]