fixed issue #31, "on multi-monitor OS X host: cursor can get locked to fullscreen display for guest OS"

This commit is contained in:
David Ludwig 2017-09-04 11:41:26 -04:00
parent 7a36983f11
commit 573ffee8b1
2 changed files with 18 additions and 11 deletions

View File

@ -56,3 +56,8 @@ bool is_fullscreen_osx(SDL_Window * window)
const NSWindowStyleMask styleMask = [wmInfo.info.cocoa.window styleMask]; const NSWindowStyleMask styleMask = [wmInfo.info.cocoa.window styleMask];
return (styleMask & NSWindowStyleMaskFullScreen) != 0; return (styleMask & NSWindowStyleMaskFullScreen) != 0;
} }
void set_menu_bar_visible_osx(bool visible)
{
[NSMenu setMenuBarVisible:(visible ? YES : NO)];
}

View File

@ -1062,7 +1062,7 @@ void driver_base::toggle_mouse_grab(void)
static void update_mouse_grab() static void update_mouse_grab()
{ {
if (mouse_grabbed || is_fullscreen(sdl_window)) { if (mouse_grabbed) {
SDL_SetRelativeMouseMode(SDL_TRUE); SDL_SetRelativeMouseMode(SDL_TRUE);
} else { } else {
SDL_SetRelativeMouseMode(SDL_FALSE); SDL_SetRelativeMouseMode(SDL_FALSE);
@ -1978,7 +1978,7 @@ enum : int {
EVENT_DROP_FROM_QUEUE = 0, EVENT_DROP_FROM_QUEUE = 0,
EVENT_ADD_TO_QUEUE = 1 EVENT_ADD_TO_QUEUE = 1
}; };
// Some events need to be processed in the host-app's main thread, due to // Some events need to be processed in the host-app's main thread, due to
// host-OS requirements. // host-OS requirements.
// //
@ -2014,15 +2014,17 @@ static int SDLCALL on_sdl_event_generated(void *userdata, SDL_Event * event)
(display_type == DISPLAY_SCREEN && !is_full); (display_type == DISPLAY_SCREEN && !is_full);
if (adjust_fullscreen) { if (adjust_fullscreen) {
do_toggle_fullscreen(); do_toggle_fullscreen();
// Utilizing SDL2's 'relative mouse mode', when in fullscreen, #if __MACOSX__
// fixes an issue on OSX hosts whereby a fullscreen window // HACK-FIX: on OSX hosts, make sure that the OSX menu
// can, in some cases, be dragged around. // bar does not show up in fullscreen mode, when the
// ( https://github.com/DavidLudwig/macemu/issues/19 ) // cursor is near the top of the screen, lest the
// // guest OS' menu bar be obscured.
// Calling update_mouse_grab() will lead to SDL_SetRelativeMouseMode() if (is_full) {
// being called, as appropriate. extern void set_menu_bar_visible_osx(bool);
update_mouse_grab(); set_menu_bar_visible_osx(false);
}
#endif
} }
} break; } break;
} }