mirror of https://github.com/encounter/SDL.git
wayland: Fix returning to a window from fullscreen without calling SetWindowSize
This commit is contained in:
parent
8da0dd17a1
commit
7f261d3b76
|
@ -61,10 +61,10 @@ CommitMinMaxDimensions(SDL_Window *window)
|
|||
max_width = window->max_w;
|
||||
max_height = window->max_h;
|
||||
} else {
|
||||
min_width = window->w;
|
||||
min_height = window->h;
|
||||
max_width = window->w;
|
||||
max_height = window->h;
|
||||
min_width = window->windowed.w;
|
||||
min_height = window->windowed.h;
|
||||
max_width = window->windowed.w;
|
||||
max_height = window->windowed.h;
|
||||
}
|
||||
|
||||
if (data->shell.xdg) {
|
||||
|
@ -1002,6 +1002,20 @@ Wayland_SetWindowFullscreen(_THIS, SDL_Window * window,
|
|||
{
|
||||
struct wl_output *output = ((SDL_WaylandOutputData*) _display->driverdata)->output;
|
||||
SetFullscreen(window, fullscreen ? output : NULL);
|
||||
|
||||
/* The window may have been resized to the output size, so reset this when
|
||||
* returning to a window
|
||||
*/
|
||||
if (!fullscreen) {
|
||||
SDL_WindowData *wind = (SDL_WindowData*) window->driverdata;
|
||||
wind->resize.width = window->windowed.w;
|
||||
wind->resize.height = window->windowed.h;
|
||||
wind->resize.pending = SDL_TRUE;
|
||||
|
||||
if (!(window->flags & SDL_WINDOW_OPENGL)) {
|
||||
Wayland_HandlePendingResize(window);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
|
|
Loading…
Reference in New Issue