summaryrefslogtreecommitdiffstats
path: root/winit
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2020-06-25 17:03:35 +0200
committerLibravatar GitHub <noreply@github.com>2020-06-25 17:03:35 +0200
commit754b8f819e223c7d31f633f43d322dcc0a0d3b93 (patch)
tree16747b2f7866f12591ac3b223070bd3fd54f12da /winit
parent038f75eef160767e83fb65445a94ff1a2b81e287 (diff)
parent65a4dca0d965ca963428231173ca5fb9c672ab52 (diff)
downloadiced-754b8f819e223c7d31f633f43d322dcc0a0d3b93.tar.gz
iced-754b8f819e223c7d31f633f43d322dcc0a0d3b93.tar.bz2
iced-754b8f819e223c7d31f633f43d322dcc0a0d3b93.zip
Merge pull request #424 from hecrj/feature/window-max-and-min-size
Add `min_size` and `max_size` to `window::Settings`
Diffstat (limited to '')
-rw-r--r--winit/src/settings.rs18
1 files changed, 18 insertions, 0 deletions
diff --git a/winit/src/settings.rs b/winit/src/settings.rs
index 37cb832f..6799f23f 100644
--- a/winit/src/settings.rs
+++ b/winit/src/settings.rs
@@ -33,6 +33,12 @@ pub struct Window {
/// The size of the window.
pub size: (u32, u32),
+ /// The minimum size of the window.
+ pub min_size: Option<(u32, u32)>,
+
+ /// The maximum size of the window.
+ pub max_size: Option<(u32, u32)>,
+
/// Whether the window should be resizable or not.
pub resizable: bool,
@@ -62,6 +68,16 @@ impl Window {
.with_decorations(self.decorations)
.with_fullscreen(conversion::fullscreen(primary_monitor, mode));
+ if let Some((width, height)) = self.min_size {
+ window_builder = window_builder
+ .with_min_inner_size(winit::dpi::LogicalSize { width, height });
+ }
+
+ if let Some((width, height)) = self.max_size {
+ window_builder = window_builder
+ .with_max_inner_size(winit::dpi::LogicalSize { width, height });
+ }
+
#[cfg(target_os = "windows")]
{
use winit::platform::windows::WindowBuilderExtWindows;
@@ -79,6 +95,8 @@ impl Default for Window {
fn default() -> Window {
Window {
size: (1024, 768),
+ min_size: None,
+ max_size: None,
resizable: true,
decorations: true,
platform_specific: Default::default(),