|
@@ -1947,12 +1947,6 @@ int SDL_RecreateWindow(SDL_Window *window, Uint32 flags)
|
|
|
/* Tear down the old native window */
|
|
|
SDL_DestroyWindowSurface(window);
|
|
|
|
|
|
- if (_this->checked_texture_framebuffer) { /* never checked? No framebuffer to destroy. Don't risk calling the wrong implementation. */
|
|
|
- if (_this->DestroyWindowFramebuffer) {
|
|
|
- _this->DestroyWindowFramebuffer(_this, window);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
if (_this->DestroyWindow && !(flags & SDL_WINDOW_FOREIGN)) {
|
|
|
_this->DestroyWindow(_this, window);
|
|
|
}
|
|
@@ -2667,55 +2661,57 @@ static SDL_Surface *SDL_CreateWindowFramebuffer(SDL_Window *window)
|
|
|
using a GPU texture through the 2D render API, if we think this would
|
|
|
be more efficient. This only checks once, on demand. */
|
|
|
if (!_this->checked_texture_framebuffer) {
|
|
|
- SDL_bool attempt_texture_framebuffer = SDL_TRUE;
|
|
|
-
|
|
|
- /* See if the user or application wants to specifically disable the framebuffer */
|
|
|
- const char *hint = SDL_GetHint(SDL_HINT_FRAMEBUFFER_ACCELERATION);
|
|
|
- if (hint) {
|
|
|
- if ((*hint == '0') || (SDL_strcasecmp(hint, "false") == 0) || (SDL_strcasecmp(hint, "software") == 0)) {
|
|
|
- attempt_texture_framebuffer = SDL_FALSE;
|
|
|
- }
|
|
|
- }
|
|
|
+ SDL_bool attempt_texture_framebuffer;
|
|
|
|
|
|
if (_this->is_dummy) { /* dummy driver never has GPU support, of course. */
|
|
|
attempt_texture_framebuffer = SDL_FALSE;
|
|
|
- }
|
|
|
+ } else {
|
|
|
+ /* See if the user or application wants to specifically disable the framebuffer */
|
|
|
+ const char *hint = SDL_GetHint(SDL_HINT_FRAMEBUFFER_ACCELERATION);
|
|
|
+ if (hint && *hint) {
|
|
|
+ if ((*hint == '0') || (SDL_strcasecmp(hint, "false") == 0) || (SDL_strcasecmp(hint, "software") == 0)) {
|
|
|
+ attempt_texture_framebuffer = SDL_FALSE;
|
|
|
+ } else {
|
|
|
+ attempt_texture_framebuffer = SDL_TRUE;
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ attempt_texture_framebuffer = SDL_TRUE;
|
|
|
|
|
|
#if defined(__LINUX__)
|
|
|
- /* On WSL, direct X11 is faster than using OpenGL for window framebuffers, so try to detect WSL and avoid texture framebuffer. */
|
|
|
- else if ((_this->CreateWindowFramebuffer) && (SDL_strcmp(_this->name, "x11") == 0)) {
|
|
|
- struct stat sb;
|
|
|
- if ((stat("/proc/sys/fs/binfmt_misc/WSLInterop", &sb) == 0) || (stat("/run/WSL", &sb) == 0)) { /* if either of these exist, we're on WSL. */
|
|
|
- attempt_texture_framebuffer = SDL_FALSE;
|
|
|
+ /* On WSL, direct X11 is faster than using OpenGL for window framebuffers, so try to detect WSL and avoid texture framebuffer. */
|
|
|
+ if ((_this->CreateWindowFramebuffer) && (SDL_strcmp(_this->name, "x11") == 0)) {
|
|
|
+ struct stat sb;
|
|
|
+ if ((stat("/proc/sys/fs/binfmt_misc/WSLInterop", &sb) == 0) || (stat("/run/WSL", &sb) == 0)) { /* if either of these exist, we're on WSL. */
|
|
|
+ attempt_texture_framebuffer = SDL_FALSE;
|
|
|
+ }
|
|
|
}
|
|
|
- }
|
|
|
#endif
|
|
|
#if defined(__WIN32__) || defined(__WINGDK__) /* GDI BitBlt() is way faster than Direct3D dynamic textures right now. (!!! FIXME: is this still true?) */
|
|
|
- else if ((_this->CreateWindowFramebuffer) && (SDL_strcmp(_this->name, "windows") == 0)) {
|
|
|
- attempt_texture_framebuffer = SDL_FALSE;
|
|
|
- }
|
|
|
+ if ((_this->CreateWindowFramebuffer) && (SDL_strcmp(_this->name, "windows") == 0)) {
|
|
|
+ attempt_texture_framebuffer = SDL_FALSE;
|
|
|
+ }
|
|
|
#endif
|
|
|
#if defined(__EMSCRIPTEN__)
|
|
|
- else {
|
|
|
attempt_texture_framebuffer = SDL_FALSE;
|
|
|
- }
|
|
|
#endif
|
|
|
+ }
|
|
|
|
|
|
- if (attempt_texture_framebuffer) {
|
|
|
- if (SDL_CreateWindowTexture(_this, window, &format, &pixels, &pitch) == -1) {
|
|
|
- /* !!! FIXME: if this failed halfway (made renderer, failed to make texture, etc),
|
|
|
- !!! FIXME: we probably need to clean this up so it doesn't interfere with
|
|
|
- !!! FIXME: a software fallback at the system level (can we blit to an
|
|
|
- !!! FIXME: OpenGL window? etc). */
|
|
|
- } else {
|
|
|
- /* future attempts will just try to use a texture framebuffer. */
|
|
|
- /* !!! FIXME: maybe we shouldn't override these but check if we used a texture
|
|
|
- !!! FIXME: framebuffer at the right places; is it feasible we could have an
|
|
|
- !!! FIXME: accelerated OpenGL window and a second ends up in software? */
|
|
|
- _this->CreateWindowFramebuffer = SDL_CreateWindowTexture;
|
|
|
- _this->UpdateWindowFramebuffer = SDL_UpdateWindowTexture;
|
|
|
- _this->DestroyWindowFramebuffer = SDL_DestroyWindowTexture;
|
|
|
- created_framebuffer = SDL_TRUE;
|
|
|
+ if (attempt_texture_framebuffer) {
|
|
|
+ if (SDL_CreateWindowTexture(_this, window, &format, &pixels, &pitch) == -1) {
|
|
|
+ /* !!! FIXME: if this failed halfway (made renderer, failed to make texture, etc),
|
|
|
+ !!! FIXME: we probably need to clean this up so it doesn't interfere with
|
|
|
+ !!! FIXME: a software fallback at the system level (can we blit to an
|
|
|
+ !!! FIXME: OpenGL window? etc). */
|
|
|
+ } else {
|
|
|
+ /* future attempts will just try to use a texture framebuffer. */
|
|
|
+ /* !!! FIXME: maybe we shouldn't override these but check if we used a texture
|
|
|
+ !!! FIXME: framebuffer at the right places; is it feasible we could have an
|
|
|
+ !!! FIXME: accelerated OpenGL window and a second ends up in software? */
|
|
|
+ _this->CreateWindowFramebuffer = SDL_CreateWindowTexture;
|
|
|
+ _this->UpdateWindowFramebuffer = SDL_UpdateWindowTexture;
|
|
|
+ _this->DestroyWindowFramebuffer = SDL_DestroyWindowTexture;
|
|
|
+ created_framebuffer = SDL_TRUE;
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -2724,6 +2720,7 @@ static SDL_Surface *SDL_CreateWindowFramebuffer(SDL_Window *window)
|
|
|
|
|
|
if (!created_framebuffer) {
|
|
|
if (!_this->CreateWindowFramebuffer || !_this->UpdateWindowFramebuffer) {
|
|
|
+ SDL_SetError("Window framebuffer support not available");
|
|
|
return NULL;
|
|
|
}
|
|
|
|
|
@@ -2733,6 +2730,7 @@ static SDL_Surface *SDL_CreateWindowFramebuffer(SDL_Window *window)
|
|
|
}
|
|
|
|
|
|
if (window->surface) {
|
|
|
+ /* We may have gone recursive and already created the surface */
|
|
|
return window->surface;
|
|
|
}
|
|
|
|
|
@@ -2755,7 +2753,12 @@ SDL_Surface *SDL_GetWindowSurface(SDL_Window *window)
|
|
|
CHECK_WINDOW_MAGIC(window, NULL);
|
|
|
|
|
|
if (!window->surface_valid) {
|
|
|
- SDL_DestroyWindowSurface(window);
|
|
|
+ if (window->surface) {
|
|
|
+ window->surface->flags &= ~SDL_DONTFREE;
|
|
|
+ SDL_FreeSurface(window->surface);
|
|
|
+ window->surface = NULL;
|
|
|
+ }
|
|
|
+
|
|
|
window->surface = SDL_CreateWindowFramebuffer(window);
|
|
|
if (window->surface) {
|
|
|
window->surface_valid = SDL_TRUE;
|
|
@@ -2792,6 +2795,25 @@ int SDL_UpdateWindowSurfaceRects(SDL_Window *window, const SDL_Rect *rects,
|
|
|
return _this->UpdateWindowFramebuffer(_this, window, rects, numrects);
|
|
|
}
|
|
|
|
|
|
+int SDL_DestroyWindowSurface(SDL_Window *window)
|
|
|
+{
|
|
|
+ CHECK_WINDOW_MAGIC(window, -1);
|
|
|
+
|
|
|
+ if (window->surface) {
|
|
|
+ window->surface->flags &= ~SDL_DONTFREE;
|
|
|
+ SDL_FreeSurface(window->surface);
|
|
|
+ window->surface = NULL;
|
|
|
+ window->surface_valid = SDL_FALSE;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (_this->checked_texture_framebuffer) { /* never checked? No framebuffer to destroy. Don't risk calling the wrong implementation. */
|
|
|
+ if (_this->DestroyWindowFramebuffer) {
|
|
|
+ _this->DestroyWindowFramebuffer(_this, window);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
int SDL_SetWindowBrightness(SDL_Window * window, float brightness)
|
|
|
{
|
|
|
Uint16 ramp[256];
|
|
@@ -2837,19 +2859,6 @@ int SDL_SetWindowOpacity(SDL_Window * window, float opacity)
|
|
|
return retval;
|
|
|
}
|
|
|
|
|
|
-int SDL_DestroyWindowSurface(SDL_Window *window)
|
|
|
-{
|
|
|
- CHECK_WINDOW_MAGIC(window, -1);
|
|
|
-
|
|
|
- if (window->surface) {
|
|
|
- window->surface->flags &= ~SDL_DONTFREE;
|
|
|
- SDL_FreeSurface(window->surface);
|
|
|
- window->surface = NULL;
|
|
|
- window->surface_valid = SDL_FALSE;
|
|
|
- }
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
int SDL_GetWindowOpacity(SDL_Window *window, float *out_opacity)
|
|
|
{
|
|
|
CHECK_WINDOW_MAGIC(window, -1);
|
|
@@ -3288,19 +3297,15 @@ void SDL_DestroyWindow(SDL_Window *window)
|
|
|
SDL_SetMouseFocus(NULL);
|
|
|
}
|
|
|
|
|
|
- /* make no context current if this is the current context window. */
|
|
|
+ SDL_DestroyWindowSurface(window);
|
|
|
+
|
|
|
+ /* Make no context current if this is the current context window */
|
|
|
if (window->flags & SDL_WINDOW_OPENGL) {
|
|
|
if (_this->current_glwin == window) {
|
|
|
SDL_GL_MakeCurrent(window, NULL);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- SDL_DestroyWindowSurface(window);
|
|
|
- if (_this->checked_texture_framebuffer) { /* never checked? No framebuffer to destroy. Don't risk calling the wrong implementation. */
|
|
|
- if (_this->DestroyWindowFramebuffer) {
|
|
|
- _this->DestroyWindowFramebuffer(_this, window);
|
|
|
- }
|
|
|
- }
|
|
|
if (_this->DestroyWindow) {
|
|
|
_this->DestroyWindow(_this, window);
|
|
|
}
|