Merge pull request #261 from Frassle/resize
X11: Fix so ClientSize can resize windows with fixed borders
This commit is contained in:
commit
e6e8b7a357
2 changed files with 18 additions and 6 deletions
|
@ -417,8 +417,7 @@ namespace OpenTK.Platform
|
|||
}
|
||||
set
|
||||
{
|
||||
Rectangle old = ClientRectangle;
|
||||
ClientRectangle = new Rectangle(old.X, old.Y, value, old.Height);
|
||||
ClientSize = new Size(value, ClientSize.Height);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -430,8 +429,7 @@ namespace OpenTK.Platform
|
|||
}
|
||||
set
|
||||
{
|
||||
Rectangle old = ClientRectangle;
|
||||
Bounds = new Rectangle(old.X, old.Y, old.Width, value);
|
||||
ClientSize = new Size(ClientSize.Width, value);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -1072,11 +1072,25 @@ namespace OpenTK.Platform.X11
|
|||
}
|
||||
set
|
||||
{
|
||||
bool is_size_changed = client_rectangle.Size != value;
|
||||
|
||||
int width = value.Width;
|
||||
int height = value.Height;
|
||||
|
||||
if (WindowBorder != WindowBorder.Resizable)
|
||||
{
|
||||
SetWindowMinMax(width, height, width, height);
|
||||
}
|
||||
|
||||
using (new XLock(window.Display))
|
||||
{
|
||||
Functions.XResizeWindow(window.Display, window.Handle,
|
||||
value.Width, value.Height);
|
||||
if (is_size_changed)
|
||||
{
|
||||
Functions.XResizeWindow(window.Display, window.Handle,
|
||||
width, height);
|
||||
}
|
||||
}
|
||||
|
||||
ProcessEvents();
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue