mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-17 14:47:19 +01:00
Added a hint SDL_HINT_VIDEO_FULLSCREEN_SPACES to specify that windows go fullscreen into their own spaces on Mac OS X.
This commit is contained in:
parent
5f8a0b18d3
commit
75145ea023
@ -178,6 +178,16 @@ extern "C" {
|
|||||||
*/
|
*/
|
||||||
#define SDL_HINT_VIDEO_MINIMIZE_ON_FOCUS_LOSS "SDL_VIDEO_MINIMIZE_ON_FOCUS_LOSS"
|
#define SDL_HINT_VIDEO_MINIMIZE_ON_FOCUS_LOSS "SDL_VIDEO_MINIMIZE_ON_FOCUS_LOSS"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Set whether windows go fullscreen in their own spaces on Mac OS X
|
||||||
|
*
|
||||||
|
* This variable can be set to the following values:
|
||||||
|
* "0" - Fullscreen windows will use the classic fullscreen mode
|
||||||
|
* "1" - Fullscreen windows will use fullscreen spaces
|
||||||
|
*
|
||||||
|
* By default SDL will use the classic fullscreen mode.
|
||||||
|
*/
|
||||||
|
#define SDL_HINT_VIDEO_FULLSCREEN_SPACES "SDL_VIDEO_FULLSCREEN_SPACES"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief A variable controlling whether the idle timer is disabled on iOS.
|
* \brief A variable controlling whether the idle timer is disabled on iOS.
|
||||||
|
@ -112,6 +112,13 @@ static SDL_VideoDevice *_this = NULL;
|
|||||||
return retval; \
|
return retval; \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __MACOSX__
|
||||||
|
/* Support for Mac OS X fullscreen spaces */
|
||||||
|
extern SDL_bool Cocoa_SetWindowFullscreenSpace(SDL_Window * window, SDL_bool state);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* Support for framebuffer emulation using an accelerated renderer */
|
/* Support for framebuffer emulation using an accelerated renderer */
|
||||||
|
|
||||||
#define SDL_WINDOWTEXTUREDATA "_SDL_WindowTextureData"
|
#define SDL_WINDOWTEXTUREDATA "_SDL_WindowTextureData"
|
||||||
@ -1080,9 +1087,17 @@ SDL_RestoreMousePosition(SDL_Window *window)
|
|||||||
static void
|
static void
|
||||||
SDL_UpdateFullscreenMode(SDL_Window * window, SDL_bool fullscreen)
|
SDL_UpdateFullscreenMode(SDL_Window * window, SDL_bool fullscreen)
|
||||||
{
|
{
|
||||||
SDL_VideoDisplay *display = SDL_GetDisplayForWindow(window);
|
SDL_VideoDisplay *display;
|
||||||
SDL_Window *other;
|
SDL_Window *other;
|
||||||
|
|
||||||
|
#ifdef __MACOSX__
|
||||||
|
if (Cocoa_SetWindowFullscreenSpace(window, fullscreen)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
display = SDL_GetDisplayForWindow(window);
|
||||||
|
|
||||||
if (fullscreen) {
|
if (fullscreen) {
|
||||||
/* Hide any other fullscreen windows */
|
/* Hide any other fullscreen windows */
|
||||||
if (display->fullscreen_window &&
|
if (display->fullscreen_window &&
|
||||||
|
@ -49,7 +49,8 @@ typedef enum
|
|||||||
-(void) pauseVisibleObservation;
|
-(void) pauseVisibleObservation;
|
||||||
-(void) resumeVisibleObservation;
|
-(void) resumeVisibleObservation;
|
||||||
-(BOOL) setFullscreenSpace:(BOOL) state;
|
-(BOOL) setFullscreenSpace:(BOOL) state;
|
||||||
-(BOOL) isInFullscreenTransition;
|
-(BOOL) isInFullscreenSpace;
|
||||||
|
-(BOOL) isInFullscreenSpaceTransition;
|
||||||
-(void) addPendingWindowOperation:(PendingWindowOperation) operation;
|
-(void) addPendingWindowOperation:(PendingWindowOperation) operation;
|
||||||
-(void) close;
|
-(void) close;
|
||||||
|
|
||||||
|
@ -189,9 +189,7 @@ GetWindowStyle(SDL_Window * window)
|
|||||||
#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1070
|
#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1070
|
||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
NSWindow *nswindow = _data->nswindow;
|
NSWindow *nswindow = _data->nswindow;
|
||||||
BOOL canSetSpace = NO;
|
|
||||||
|
|
||||||
/* Make sure the window supports switching to fullscreen spaces */
|
|
||||||
if (![nswindow respondsToSelector: @selector(collectionBehavior)]) {
|
if (![nswindow respondsToSelector: @selector(collectionBehavior)]) {
|
||||||
return NO;
|
return NO;
|
||||||
}
|
}
|
||||||
@ -199,22 +197,6 @@ GetWindowStyle(SDL_Window * window)
|
|||||||
return NO;
|
return NO;
|
||||||
}
|
}
|
||||||
|
|
||||||
pendingWindowOperation = PENDING_OPERATION_NONE;
|
|
||||||
|
|
||||||
/* We can enter fullscreen spaces for "fullscreen desktop" */
|
|
||||||
if ((window->flags & SDL_WINDOW_FULLSCREEN_DESKTOP) == SDL_WINDOW_FULLSCREEN_DESKTOP) {
|
|
||||||
canSetSpace = YES;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* We can always leave fullscreen spaces */
|
|
||||||
if (!state && isFullscreenSpace) {
|
|
||||||
canSetSpace = YES;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!canSetSpace) {
|
|
||||||
return NO;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (state == isFullscreenSpace) {
|
if (state == isFullscreenSpace) {
|
||||||
return YES;
|
return YES;
|
||||||
}
|
}
|
||||||
@ -227,6 +209,14 @@ GetWindowStyle(SDL_Window * window)
|
|||||||
}
|
}
|
||||||
return YES;
|
return YES;
|
||||||
}
|
}
|
||||||
|
inFullscreenTransition = YES;
|
||||||
|
|
||||||
|
/* Update the flags here so the state change is available immediately */
|
||||||
|
if (state) {
|
||||||
|
window->flags |= SDL_WINDOW_FULLSCREEN_DESKTOP;
|
||||||
|
} else {
|
||||||
|
window->flags &= ~SDL_WINDOW_FULLSCREEN_DESKTOP;
|
||||||
|
}
|
||||||
|
|
||||||
[nswindow performSelectorOnMainThread: @selector(toggleFullScreen:) withObject:nswindow waitUntilDone:NO];
|
[nswindow performSelectorOnMainThread: @selector(toggleFullScreen:) withObject:nswindow waitUntilDone:NO];
|
||||||
return YES;
|
return YES;
|
||||||
@ -235,7 +225,12 @@ GetWindowStyle(SDL_Window * window)
|
|||||||
#endif /* SDK >= 10.7 */
|
#endif /* SDK >= 10.7 */
|
||||||
}
|
}
|
||||||
|
|
||||||
-(BOOL) isInFullscreenTransition
|
-(BOOL) isInFullscreenSpace
|
||||||
|
{
|
||||||
|
return isFullscreenSpace;
|
||||||
|
}
|
||||||
|
|
||||||
|
-(BOOL) isInFullscreenSpaceTransition
|
||||||
{
|
{
|
||||||
return inFullscreenTransition;
|
return inFullscreenTransition;
|
||||||
}
|
}
|
||||||
@ -429,13 +424,8 @@ GetWindowStyle(SDL_Window * window)
|
|||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
NSWindow *nswindow = _data->nswindow;
|
NSWindow *nswindow = _data->nswindow;
|
||||||
|
|
||||||
if (!(window->flags & SDL_WINDOW_RESIZABLE)) {
|
window->flags |= SDL_WINDOW_FULLSCREEN_DESKTOP;
|
||||||
if ((window->flags & SDL_WINDOW_FULLSCREEN_DESKTOP) == SDL_WINDOW_FULLSCREEN_DESKTOP) {
|
|
||||||
[nswindow setStyleMask:(NSTitledWindowMask|NSClosableWindowMask|NSMiniaturizableWindowMask|NSResizableWindowMask)];
|
[nswindow setStyleMask:(NSTitledWindowMask|NSClosableWindowMask|NSMiniaturizableWindowMask|NSResizableWindowMask)];
|
||||||
} else {
|
|
||||||
[nswindow setStyleMask:NSBorderlessWindowMask];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
isFullscreenSpace = YES;
|
isFullscreenSpace = YES;
|
||||||
inFullscreenTransition = YES;
|
inFullscreenTransition = YES;
|
||||||
@ -444,7 +434,6 @@ GetWindowStyle(SDL_Window * window)
|
|||||||
- (void)windowDidEnterFullScreen:(NSNotification *)aNotification
|
- (void)windowDidEnterFullScreen:(NSNotification *)aNotification
|
||||||
{
|
{
|
||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
NSWindow *nswindow = _data->nswindow;
|
|
||||||
|
|
||||||
inFullscreenTransition = NO;
|
inFullscreenTransition = NO;
|
||||||
|
|
||||||
@ -467,12 +456,8 @@ GetWindowStyle(SDL_Window * window)
|
|||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
NSWindow *nswindow = _data->nswindow;
|
NSWindow *nswindow = _data->nswindow;
|
||||||
|
|
||||||
if (!(window->flags & SDL_WINDOW_RESIZABLE)) {
|
|
||||||
Uint32 flags = window->flags;
|
|
||||||
window->flags &= ~SDL_WINDOW_FULLSCREEN_DESKTOP;
|
window->flags &= ~SDL_WINDOW_FULLSCREEN_DESKTOP;
|
||||||
[nswindow setStyleMask:GetWindowStyle(window)];
|
[nswindow setStyleMask:GetWindowStyle(window)];
|
||||||
window->flags = flags;
|
|
||||||
}
|
|
||||||
|
|
||||||
isFullscreenSpace = NO;
|
isFullscreenSpace = NO;
|
||||||
inFullscreenTransition = YES;
|
inFullscreenTransition = YES;
|
||||||
@ -925,8 +910,11 @@ Cocoa_CreateWindow(_THIS, SDL_Window * window)
|
|||||||
[nswindow setBackgroundColor:[NSColor blackColor]];
|
[nswindow setBackgroundColor:[NSColor blackColor]];
|
||||||
#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1070
|
#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1070
|
||||||
if ([nswindow respondsToSelector:@selector(setCollectionBehavior:)]) {
|
if ([nswindow respondsToSelector:@selector(setCollectionBehavior:)]) {
|
||||||
|
const char *hint = SDL_GetHint(SDL_HINT_VIDEO_FULLSCREEN_SPACES);
|
||||||
|
if (hint && SDL_atoi(hint) > 0) {
|
||||||
[nswindow setCollectionBehavior:NSWindowCollectionBehaviorFullScreenPrimary];
|
[nswindow setCollectionBehavior:NSWindowCollectionBehaviorFullScreenPrimary];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Create a default view for this window */
|
/* Create a default view for this window */
|
||||||
@ -1139,7 +1127,7 @@ Cocoa_MinimizeWindow(_THIS, SDL_Window * window)
|
|||||||
SDL_WindowData *data = (SDL_WindowData *) window->driverdata;
|
SDL_WindowData *data = (SDL_WindowData *) window->driverdata;
|
||||||
NSWindow *nswindow = data->nswindow;
|
NSWindow *nswindow = data->nswindow;
|
||||||
|
|
||||||
if ([data->listener isInFullscreenTransition]) {
|
if ([data->listener isInFullscreenSpaceTransition]) {
|
||||||
[data->listener addPendingWindowOperation:PENDING_OPERATION_MINIMIZE];
|
[data->listener addPendingWindowOperation:PENDING_OPERATION_MINIMIZE];
|
||||||
} else {
|
} else {
|
||||||
[nswindow miniaturize:nil];
|
[nswindow miniaturize:nil];
|
||||||
@ -1196,9 +1184,10 @@ Cocoa_SetWindowBordered(_THIS, SDL_Window * window, SDL_bool bordered)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
void
|
||||||
Cocoa_SetWindowFullscreen_OldStyle(_THIS, SDL_Window * window, SDL_VideoDisplay * display, SDL_bool fullscreen)
|
Cocoa_SetWindowFullscreen(_THIS, SDL_Window * window, SDL_VideoDisplay * display, SDL_bool fullscreen)
|
||||||
{
|
{
|
||||||
|
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
|
||||||
SDL_WindowData *data = (SDL_WindowData *) window->driverdata;
|
SDL_WindowData *data = (SDL_WindowData *) window->driverdata;
|
||||||
NSWindow *nswindow = data->nswindow;
|
NSWindow *nswindow = data->nswindow;
|
||||||
NSRect rect;
|
NSRect rect;
|
||||||
@ -1272,17 +1261,6 @@ Cocoa_SetWindowFullscreen_OldStyle(_THIS, SDL_Window * window, SDL_VideoDisplay
|
|||||||
}
|
}
|
||||||
|
|
||||||
ScheduleContextUpdates(data);
|
ScheduleContextUpdates(data);
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
Cocoa_SetWindowFullscreen(_THIS, SDL_Window * window, SDL_VideoDisplay * display, SDL_bool fullscreen)
|
|
||||||
{
|
|
||||||
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
|
|
||||||
SDL_WindowData *data = (SDL_WindowData *) window->driverdata;
|
|
||||||
|
|
||||||
if (![data->listener setFullscreenSpace:(fullscreen ? YES : NO)]) {
|
|
||||||
Cocoa_SetWindowFullscreen_OldStyle(_this, window, display, fullscreen);
|
|
||||||
}
|
|
||||||
|
|
||||||
[pool release];
|
[pool release];
|
||||||
}
|
}
|
||||||
@ -1404,6 +1382,24 @@ Cocoa_GetWindowWMInfo(_THIS, SDL_Window * window, SDL_SysWMinfo * info)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SDL_bool
|
||||||
|
Cocoa_SetWindowFullscreenSpace(SDL_Window * window, SDL_bool state)
|
||||||
|
{
|
||||||
|
SDL_bool succeeded = SDL_FALSE;
|
||||||
|
#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1070
|
||||||
|
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
|
||||||
|
SDL_WindowData *data = (SDL_WindowData *) window->driverdata;
|
||||||
|
|
||||||
|
if ([data->listener setFullscreenSpace:(state ? YES : NO)]) {
|
||||||
|
succeeded = SDL_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
[pool release];
|
||||||
|
#endif /* SDK 10.7+ */
|
||||||
|
|
||||||
|
return succeeded;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* SDL_VIDEO_DRIVER_COCOA */
|
#endif /* SDL_VIDEO_DRIVER_COCOA */
|
||||||
|
|
||||||
/* vi: set ts=4 sw=4 expandtab: */
|
/* vi: set ts=4 sw=4 expandtab: */
|
||||||
|
Loading…
Reference in New Issue
Block a user