mirror of
https://github.com/Ryujinx/SDL.git
synced 2025-01-12 23:25:27 +00:00
Fullscreen to windowed mode switch
From Melesie I noticed that when user switches from fullscreen mode to windowed mode and exits application while in windowed mode, Windows performs an additional change of display settings, even though desktop resolution is the same as current one. This causes short black screen to show up. The only way I know of avoiding this is to explicitly switch to default display settings found in registry. MSDN documentation for ChangeDisplaySettingsEx states: Passing NULL for the lpDevMode parameter and 0 for the dwFlags parameter is the easiest way to return to the default mode after a dynamic mode change.
This commit is contained in:
parent
18c31dec54
commit
70df9cd0cd
|
@ -274,9 +274,11 @@ WIN_SetDisplayMode(_THIS, SDL_VideoDisplay * display, SDL_DisplayMode * mode)
|
||||||
SDL_DisplayModeData *data = (SDL_DisplayModeData *) mode->driverdata;
|
SDL_DisplayModeData *data = (SDL_DisplayModeData *) mode->driverdata;
|
||||||
LONG status;
|
LONG status;
|
||||||
|
|
||||||
status =
|
if (mode->driverdata == display->desktop_mode.driverdata) {
|
||||||
ChangeDisplaySettingsEx(displaydata->DeviceName, &data->DeviceMode,
|
status = ChangeDisplaySettingsEx(displaydata->DeviceName, NULL, NULL, 0, NULL);
|
||||||
NULL, CDS_FULLSCREEN, NULL);
|
} else {
|
||||||
|
status = ChangeDisplaySettingsEx(displaydata->DeviceName, &data->DeviceMode, NULL, CDS_FULLSCREEN, NULL);
|
||||||
|
}
|
||||||
if (status != DISP_CHANGE_SUCCESSFUL) {
|
if (status != DISP_CHANGE_SUCCESSFUL) {
|
||||||
const char *reason = "Unknown reason";
|
const char *reason = "Unknown reason";
|
||||||
switch (status) {
|
switch (status) {
|
||||||
|
|
Loading…
Reference in a new issue