Mac: Immediately update current OpenGL context's shape.

Previously we were postponing our -[NSOpenGLContext update] call to the next
SDL_GL_SwapWindow, even if the context was current on the current thread. This
changes it so that we will do the update immediately if it's the current
context.

If you're rendering on another thread, you need to call SDL_GL_SwapWindow once
after a resize event to ensure your drawable will produce non-garbage data.

Bug: https://bugzilla.libsdl.org/show_bug.cgi?id=2339
This commit is contained in:
J?rgen P. Tjern? 2014-02-25 15:28:12 -08:00
parent 4c192bc802
commit 95f7e242e6
2 changed files with 16 additions and 3 deletions

View File

@ -110,13 +110,21 @@
if ([self view] != [windowdata->nswindow contentView]) { if ([self view] != [windowdata->nswindow contentView]) {
[self setView:[windowdata->nswindow contentView]]; [self setView:[windowdata->nswindow contentView]];
if (self == [NSOpenGLContext currentContext]) {
[self update];
} else {
[self scheduleUpdate]; [self scheduleUpdate];
} }
}
} else { } else {
[self clearDrawable]; [self clearDrawable];
if (self == [NSOpenGLContext currentContext]) {
[self update];
} else {
[self scheduleUpdate]; [self scheduleUpdate];
} }
} }
}
@end @end

View File

@ -49,13 +49,18 @@ static void ConvertNSRect(NSRect *r)
static void static void
ScheduleContextUpdates(SDL_WindowData *data) ScheduleContextUpdates(SDL_WindowData *data)
{ {
NSOpenGLContext *currentContext = [NSOpenGLContext currentContext];
NSMutableArray *contexts = data->nscontexts; NSMutableArray *contexts = data->nscontexts;
@synchronized (contexts) { @synchronized (contexts) {
for (SDLOpenGLContext *context in contexts) { for (SDLOpenGLContext *context in contexts) {
if (context == currentContext) {
[context update];
} else {
[context scheduleUpdate]; [context scheduleUpdate];
} }
} }
} }
}
static int static int
GetHintCtrlClickEmulateRightClick() GetHintCtrlClickEmulateRightClick()