Fix issues with set_window_resizable on x11
(cherry picked from commit 474e3ac055
)
This commit is contained in:
parent
c01c5fce59
commit
97fef612fb
1 changed files with 27 additions and 9 deletions
|
@ -780,13 +780,31 @@ void OS_X11::set_window_position(const Point2& p_position) {
|
||||||
}
|
}
|
||||||
|
|
||||||
Size2 OS_X11::get_window_size() const {
|
Size2 OS_X11::get_window_size() const {
|
||||||
XWindowAttributes xwa;
|
// Use current_videomode width and height instead of XGetWindowAttributes
|
||||||
XGetWindowAttributes(x11_display, x11_window, &xwa);
|
// since right after a XResizeWindow the attributes may not be updated yet
|
||||||
return Size2i(xwa.width, xwa.height);
|
return Size2i(current_videomode.width, current_videomode.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OS_X11::set_window_size(const Size2 p_size) {
|
void OS_X11::set_window_size(const Size2 p_size) {
|
||||||
|
// If window resizable is disabled we need to update the attributes first
|
||||||
|
if (is_window_resizable() == false) {
|
||||||
|
XSizeHints *xsh;
|
||||||
|
xsh = XAllocSizeHints();
|
||||||
|
xsh->flags = PMinSize | PMaxSize;
|
||||||
|
xsh->min_width = p_size.x;
|
||||||
|
xsh->max_width = p_size.x;
|
||||||
|
xsh->min_height = p_size.y;
|
||||||
|
xsh->max_height = p_size.y;
|
||||||
|
XSetWMNormalHints(x11_display, x11_window, xsh);
|
||||||
|
XFree(xsh);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Resize the window
|
||||||
XResizeWindow(x11_display, x11_window, p_size.x, p_size.y);
|
XResizeWindow(x11_display, x11_window, p_size.x, p_size.y);
|
||||||
|
|
||||||
|
// Update our videomode width and height
|
||||||
|
current_videomode.width = p_size.x;
|
||||||
|
current_videomode.height = p_size.y;
|
||||||
}
|
}
|
||||||
|
|
||||||
void OS_X11::set_window_fullscreen(bool p_enabled) {
|
void OS_X11::set_window_fullscreen(bool p_enabled) {
|
||||||
|
@ -800,15 +818,15 @@ bool OS_X11::is_window_fullscreen() const {
|
||||||
|
|
||||||
void OS_X11::set_window_resizable(bool p_enabled) {
|
void OS_X11::set_window_resizable(bool p_enabled) {
|
||||||
XSizeHints *xsh;
|
XSizeHints *xsh;
|
||||||
|
Size2 size = get_window_size();
|
||||||
|
|
||||||
xsh = XAllocSizeHints();
|
xsh = XAllocSizeHints();
|
||||||
xsh->flags = p_enabled ? 0L : PMinSize | PMaxSize;
|
xsh->flags = p_enabled ? 0L : PMinSize | PMaxSize;
|
||||||
if(!p_enabled) {
|
if(!p_enabled) {
|
||||||
XWindowAttributes xwa;
|
xsh->min_width = size.x;
|
||||||
XGetWindowAttributes(x11_display,x11_window,&xwa);
|
xsh->max_width = size.x;
|
||||||
xsh->min_width = xwa.width;
|
xsh->min_height = size.y;
|
||||||
xsh->max_width = xwa.width;
|
xsh->max_height = size.y;
|
||||||
xsh->min_height = xwa.height;
|
|
||||||
xsh->max_height = xwa.height;
|
|
||||||
}
|
}
|
||||||
XSetWMNormalHints(x11_display, x11_window, xsh);
|
XSetWMNormalHints(x11_display, x11_window, xsh);
|
||||||
XFree(xsh);
|
XFree(xsh);
|
||||||
|
|
Loading…
Reference in a new issue