diff --git a/backends/graphics/openglsdl/openglsdl-graphics.cpp b/backends/graphics/openglsdl/openglsdl-graphics.cpp index d789e9f25bb..1ac892b5b15 100644 --- a/backends/graphics/openglsdl/openglsdl-graphics.cpp +++ b/backends/graphics/openglsdl/openglsdl-graphics.cpp @@ -40,6 +40,11 @@ OpenGLSdlGraphicsManager::OpenGLSdlGraphicsManager() // Disable OS cursor SDL_ShowCursor(SDL_DISABLE); + + // Get desktop resolution + const SDL_VideoInfo *videoInfo = SDL_GetVideoInfo(); + _desktopWidth = videoInfo->current_w; + _desktopHeight = videoInfo->current_h; } OpenGLSdlGraphicsManager::~OpenGLSdlGraphicsManager() { @@ -229,6 +234,13 @@ bool OpenGLSdlGraphicsManager::loadGFXMode() { // Iterate over all available fullscreen modes for (int i = 0; const SDL_Rect *mode = availableModes[i]; i++) { + // Prefer the native resolution over other modes + if(mode->w == _desktopWidth && mode->h == _desktopHeight) { + bestMode = mode; + bestModeIndex = i; + break; + } + if (mode->w < _videoMode.hardwareWidth) continue; if (mode->h < _videoMode.hardwareHeight) diff --git a/backends/graphics/openglsdl/openglsdl-graphics.h b/backends/graphics/openglsdl/openglsdl-graphics.h index 9b0a3df36f4..144b9613782 100644 --- a/backends/graphics/openglsdl/openglsdl-graphics.h +++ b/backends/graphics/openglsdl/openglsdl-graphics.h @@ -84,6 +84,9 @@ protected: SDL_Surface *_hwscreen; bool _screenResized; + + int _desktopWidth; + int _desktopHeight; }; #endif