mirror of https://github.com/encounter/SDL.git
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:
parent
4c192bc802
commit
95f7e242e6
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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()
|
||||||
|
|
Loading…
Reference in New Issue