Wayland: Fix maximization by user being ignored
The internal maximization state was not updated when an event was received that the user had changed the maximization state of a window, and no maximization events were emitted. This affected both the GLFW_MAXIMIZED attribute and glfwRestoreWindow.
This commit is contained in:
parent
ddd087d662
commit
f39ffefb6a
@ -335,6 +335,9 @@ information on what to include when reporting a bug.
|
|||||||
- [Wayland] Bugfix: A window leaving full screen mode ignored its desired size
|
- [Wayland] Bugfix: A window leaving full screen mode ignored its desired size
|
||||||
- [Wayland] Bugfix: `glfwSetWindowMonitor` did not update windowed mode size
|
- [Wayland] Bugfix: `glfwSetWindowMonitor` did not update windowed mode size
|
||||||
- [Wayland] Bugfix: `glfwRestoreWindow` would make a full screen window windowed
|
- [Wayland] Bugfix: `glfwRestoreWindow` would make a full screen window windowed
|
||||||
|
- [Wayland] Bugfix: A window maximized or restored by the user would enter an
|
||||||
|
inconsistent state
|
||||||
|
- [Wayland] Bugfix: Window maximization events were not emitted
|
||||||
- [POSIX] Removed use of deprecated function `gettimeofday`
|
- [POSIX] Removed use of deprecated function `gettimeofday`
|
||||||
- [POSIX] Bugfix: `CLOCK_MONOTONIC` was not correctly tested for or enabled
|
- [POSIX] Bugfix: `CLOCK_MONOTONIC` was not correctly tested for or enabled
|
||||||
- [WGL] Disabled the DWM swap interval hack for Windows 8 and later (#1072)
|
- [WGL] Disabled the DWM swap interval hack for Windows 8 and later (#1072)
|
||||||
|
@ -516,7 +516,13 @@ static void xdgToplevelHandleConfigure(void* userData,
|
|||||||
_glfwIconifyWindowWayland(window);
|
_glfwIconifyWindowWayland(window);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (window->wl.maximized && !maximized)
|
||||||
|
_glfwInputWindowMaximize(window, GLFW_FALSE);
|
||||||
|
else if (maximized && !window->wl.maximized)
|
||||||
|
_glfwInputWindowMaximize(window, GLFW_TRUE);
|
||||||
|
|
||||||
window->wl.activated = activated;
|
window->wl.activated = activated;
|
||||||
|
window->wl.maximized = maximized;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void xdgToplevelHandleClose(void* userData,
|
static void xdgToplevelHandleClose(void* userData,
|
||||||
@ -1913,18 +1919,13 @@ void _glfwRestoreWindowWayland(_GLFWwindow* window)
|
|||||||
// There is no way to unset minimized, or even to know if we are
|
// There is no way to unset minimized, or even to know if we are
|
||||||
// minimized, so there is nothing to do in this case.
|
// minimized, so there is nothing to do in this case.
|
||||||
}
|
}
|
||||||
|
|
||||||
window->wl.maximized = GLFW_FALSE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void _glfwMaximizeWindowWayland(_GLFWwindow* window)
|
void _glfwMaximizeWindowWayland(_GLFWwindow* window)
|
||||||
{
|
{
|
||||||
if (window->wl.xdg.toplevel)
|
if (window->wl.xdg.toplevel)
|
||||||
{
|
|
||||||
xdg_toplevel_set_maximized(window->wl.xdg.toplevel);
|
xdg_toplevel_set_maximized(window->wl.xdg.toplevel);
|
||||||
}
|
}
|
||||||
window->wl.maximized = GLFW_TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
void _glfwShowWindowWayland(_GLFWwindow* window)
|
void _glfwShowWindowWayland(_GLFWwindow* window)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user