From eeb3e92eb29c4fdbcdc0b0276753c1d32210a8e5 Mon Sep 17 00:00:00 2001 From: ManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com> Date: Wed, 29 Dec 2021 17:18:12 +0100 Subject: Fix fullscreen window level corner cases on macOS - cont'd See long discussion in PR#277 at https://github.com/fltk/fltk/pull/277 --- src/Fl_cocoa.mm | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/Fl_cocoa.mm b/src/Fl_cocoa.mm index f2df29a4a..ad4e21c8f 100644 --- a/src/Fl_cocoa.mm +++ b/src/Fl_cocoa.mm @@ -831,8 +831,8 @@ static NSInteger modal_window_level(void) NSInteger level; level = max_normal_window_level(); - if (level < NSModalPanelWindowLevel) - return NSModalPanelWindowLevel; + if (level < NSStatusWindowLevel) + return NSStatusWindowLevel; // Need some room for non-modal windows level += 2; @@ -1285,9 +1285,8 @@ static FLWindowDelegate *flwindowdelegate_instance = nil; FLWindow *nsw = (FLWindow*)[notif object]; Fl_Window *window = [nsw getFl_Window]; /* Fullscreen windows obscure all other windows so we need to return - to a "normal" level when the user switches to another window, - unless this other window is above the fullscreen window */ - if (window->fullscreen_active() && [NSApp keyWindow] && [[NSApp keyWindow] level] <= [nsw level]) { + to a "normal" level when the user switches to another window or another app */ + if (window->fullscreen_active()) { [nsw setLevel:NSNormalWindowLevel]; fixup_window_levels(); } -- cgit v1.2.3