mirror of https://github.com/encounter/SDL.git
Reworked fullscreen policy on Mac OS X.
- SDL_WINDOW_FULLSCREEN works as always (change resolution, lock to window). - SDL_WINDOW_FULLSCREEN_DESKTOP now puts the window in its own Space, and hides the menu bar, but you can slide between Spaces and Command-Tab between apps without the window minimizing, etc. - SDL_WINDOW_RESIZABLE windows will get the new 10.7+ "toggle fullscreen" window decoration and menubar item. As far as the app is concerned, this is no different than resizing a window, but it gives the end-user more power. - The hint for putting fullscreen windows into the Spaces system is gone, since Spaces can't enforce the requested resolution. It's a perfect match for FULLSCREEN_DESKTOP, though, so this is all automated now.
This commit is contained in:
parent
afc74d9843
commit
51faf449bb
|
@ -200,17 +200,6 @@ 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.
|
||||||
*
|
*
|
||||||
|
|
|
@ -121,7 +121,9 @@ GetWindowStyle(SDL_Window * window)
|
||||||
{
|
{
|
||||||
unsigned int style;
|
unsigned int style;
|
||||||
|
|
||||||
if (window->flags & SDL_WINDOW_FULLSCREEN) {
|
if ((window->flags & SDL_WINDOW_FULLSCREEN_DESKTOP) == SDL_WINDOW_FULLSCREEN_DESKTOP) {
|
||||||
|
style = (NSTitledWindowMask|NSClosableWindowMask|NSMiniaturizableWindowMask);
|
||||||
|
} else if (window->flags & SDL_WINDOW_FULLSCREEN) {
|
||||||
style = NSBorderlessWindowMask;
|
style = NSBorderlessWindowMask;
|
||||||
} else {
|
} else {
|
||||||
if (window->flags & SDL_WINDOW_BORDERLESS) {
|
if (window->flags & SDL_WINDOW_BORDERLESS) {
|
||||||
|
@ -256,20 +258,17 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
-(BOOL) setFullscreenSpace:(BOOL) state;
|
-(BOOL) setFullscreenSpace:(BOOL) state
|
||||||
{
|
{
|
||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
NSWindow *nswindow = _data->nswindow;
|
NSWindow *nswindow = _data->nswindow;
|
||||||
|
|
||||||
if (![nswindow respondsToSelector: @selector(collectionBehavior)]) {
|
if ((window->flags & SDL_WINDOW_FULLSCREEN_DESKTOP) != SDL_WINDOW_FULLSCREEN_DESKTOP) {
|
||||||
return NO;
|
return NO; /* we only allow this on FULLSCREEN_DESKTOP windows. */
|
||||||
}
|
} else if (![nswindow respondsToSelector: @selector(setCollectionBehavior:)]) {
|
||||||
if ([nswindow collectionBehavior] != NSWindowCollectionBehaviorFullScreenPrimary) {
|
return NO; /* No Spaces support? Older Mac OS X? */
|
||||||
return NO;
|
} else if (state == isFullscreenSpace) {
|
||||||
}
|
return YES; /* already there. */
|
||||||
|
|
||||||
if (state == isFullscreenSpace) {
|
|
||||||
return YES;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (inFullscreenTransition) {
|
if (inFullscreenTransition) {
|
||||||
|
@ -282,13 +281,8 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
}
|
}
|
||||||
inFullscreenTransition = YES;
|
inFullscreenTransition = YES;
|
||||||
|
|
||||||
/* Update the flags here so the state change is available immediately */
|
/* you need to be FullScreenPrimary, or toggleFullScreen doesn't work. Unset it again in windowDid[Enter|Exit]FullScreen. */
|
||||||
if (state) {
|
[nswindow setCollectionBehavior:NSWindowCollectionBehaviorFullScreenPrimary];
|
||||||
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;
|
||||||
}
|
}
|
||||||
|
@ -443,6 +437,11 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
|
|
||||||
- (void)windowDidResize:(NSNotification *)aNotification
|
- (void)windowDidResize:(NSNotification *)aNotification
|
||||||
{
|
{
|
||||||
|
if (inFullscreenTransition) {
|
||||||
|
/* We'll take care of this at the end of the transition */
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
NSWindow *nswindow = _data->nswindow;
|
NSWindow *nswindow = _data->nswindow;
|
||||||
int x, y, w, h;
|
int x, y, w, h;
|
||||||
|
@ -453,11 +452,6 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
w = (int)rect.size.width;
|
w = (int)rect.size.width;
|
||||||
h = (int)rect.size.height;
|
h = (int)rect.size.height;
|
||||||
|
|
||||||
if (inFullscreenTransition) {
|
|
||||||
/* We'll take care of this at the end of the transition */
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (SDL_IsShapedWindow(window)) {
|
if (SDL_IsShapedWindow(window)) {
|
||||||
Cocoa_ResizeWindowShape(window);
|
Cocoa_ResizeWindowShape(window);
|
||||||
}
|
}
|
||||||
|
@ -538,7 +532,6 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
{
|
{
|
||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
|
|
||||||
window->flags |= SDL_WINDOW_FULLSCREEN_DESKTOP;
|
|
||||||
SetWindowStyle(window, (NSTitledWindowMask|NSClosableWindowMask|NSMiniaturizableWindowMask|NSResizableWindowMask));
|
SetWindowStyle(window, (NSTitledWindowMask|NSClosableWindowMask|NSMiniaturizableWindowMask|NSResizableWindowMask));
|
||||||
|
|
||||||
isFullscreenSpace = YES;
|
isFullscreenSpace = YES;
|
||||||
|
@ -548,6 +541,7 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
- (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;
|
||||||
|
|
||||||
|
@ -555,6 +549,12 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
pendingWindowOperation = PENDING_OPERATION_NONE;
|
pendingWindowOperation = PENDING_OPERATION_NONE;
|
||||||
[self setFullscreenSpace:NO];
|
[self setFullscreenSpace:NO];
|
||||||
} else {
|
} else {
|
||||||
|
if ((window->flags & SDL_WINDOW_FULLSCREEN_DESKTOP) == SDL_WINDOW_FULLSCREEN_DESKTOP) {
|
||||||
|
/* Remove the fullscreen toggle button and menu now that we're here. */
|
||||||
|
[nswindow setCollectionBehavior:NSWindowCollectionBehaviorManaged];
|
||||||
|
[NSMenu setMenuBarVisible:NO];
|
||||||
|
}
|
||||||
|
|
||||||
pendingWindowOperation = PENDING_OPERATION_NONE;
|
pendingWindowOperation = PENDING_OPERATION_NONE;
|
||||||
/* Force the size change event in case it was delivered earlier
|
/* Force the size change event in case it was delivered earlier
|
||||||
while the window was still animating into place.
|
while the window was still animating into place.
|
||||||
|
@ -569,7 +569,6 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
{
|
{
|
||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
|
|
||||||
window->flags &= ~SDL_WINDOW_FULLSCREEN_DESKTOP;
|
|
||||||
SetWindowStyle(window, GetWindowStyle(window));
|
SetWindowStyle(window, GetWindowStyle(window));
|
||||||
|
|
||||||
isFullscreenSpace = NO;
|
isFullscreenSpace = NO;
|
||||||
|
@ -590,6 +589,12 @@ SetWindowStyle(SDL_Window * window, unsigned int style)
|
||||||
pendingWindowOperation = PENDING_OPERATION_NONE;
|
pendingWindowOperation = PENDING_OPERATION_NONE;
|
||||||
[nswindow miniaturize:nil];
|
[nswindow miniaturize:nil];
|
||||||
} else {
|
} else {
|
||||||
|
if ((window->flags & SDL_WINDOW_FULLSCREEN_DESKTOP) == SDL_WINDOW_FULLSCREEN_DESKTOP) {
|
||||||
|
/* Remove the fullscreen toggle button and readd menu now that we're here. */
|
||||||
|
[nswindow setCollectionBehavior:NSWindowCollectionBehaviorManaged];
|
||||||
|
[NSMenu setMenuBarVisible:YES];
|
||||||
|
}
|
||||||
|
|
||||||
pendingWindowOperation = PENDING_OPERATION_NONE;
|
pendingWindowOperation = PENDING_OPERATION_NONE;
|
||||||
/* Force the size change event in case it was delivered earlier
|
/* Force the size change event in case it was delivered earlier
|
||||||
while the window was still animating into place.
|
while the window was still animating into place.
|
||||||
|
@ -1007,9 +1012,11 @@ Cocoa_CreateWindow(_THIS, SDL_Window * window)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
[nswindow setBackgroundColor:[NSColor blackColor]];
|
[nswindow setBackgroundColor:[NSColor blackColor]];
|
||||||
if ([nswindow respondsToSelector:@selector(setCollectionBehavior:)]) {
|
|
||||||
const char *hint = SDL_GetHint(SDL_HINT_VIDEO_FULLSCREEN_SPACES);
|
if ([nswindow respondsToSelector: @selector(setCollectionBehavior:)]) {
|
||||||
if (hint && SDL_atoi(hint) > 0) {
|
/* we put FULLSCREEN_DESKTOP windows in their own Space, without a toggle button or menubar, later */
|
||||||
|
if (window->flags & SDL_WINDOW_RESIZABLE) {
|
||||||
|
/* resizable windows are Spaces-friendly: they get the "go fullscreen" toggle button on their titlebar. */
|
||||||
[nswindow setCollectionBehavior:NSWindowCollectionBehaviorFullScreenPrimary];
|
[nswindow setCollectionBehavior:NSWindowCollectionBehaviorFullScreenPrimary];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue