diff options
author | 2021-07-22 17:49:18 +0700 | |
---|---|---|
committer | 2021-07-22 17:49:18 +0700 | |
commit | 9cf5f3e1ef19f67b7939b9a747c2f66ad6b5275c (patch) | |
tree | 4c9af75c3a0b7d0d7a5e664ec55fbdbc24cd9f88 /winit/src/settings.rs | |
parent | 8fe8b6b168f193fadb495c78c076262d9114b14e (diff) | |
parent | 39b8f7de50ca53c67214c4ec2af2d3a0944f006a (diff) | |
download | iced-9cf5f3e1ef19f67b7939b9a747c2f66ad6b5275c.tar.gz iced-9cf5f3e1ef19f67b7939b9a747c2f66ad6b5275c.tar.bz2 iced-9cf5f3e1ef19f67b7939b9a747c2f66ad6b5275c.zip |
Merge pull request #929 from TimUntersberger/winit-improv
feat: add position to window settings
Diffstat (limited to 'winit/src/settings.rs')
-rw-r--r-- | winit/src/settings.rs | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/winit/src/settings.rs b/winit/src/settings.rs index 941d88ce..743f79bc 100644 --- a/winit/src/settings.rs +++ b/winit/src/settings.rs @@ -9,7 +9,7 @@ mod platform; pub use platform::PlatformSpecific; use crate::conversion; -use crate::Mode; +use crate::{Mode, Position}; use winit::monitor::MonitorHandle; use winit::window::WindowBuilder; @@ -35,6 +35,9 @@ pub struct Window { /// The size of the window. pub size: (u32, u32), + /// The position of the window. + pub position: Position, + /// The minimum size of the window. pub min_size: Option<(u32, u32)>, @@ -80,9 +83,16 @@ impl Window { .with_transparent(self.transparent) .with_window_icon(self.icon) .with_always_on_top(self.always_on_top) - .with_fullscreen(conversion::fullscreen(primary_monitor, mode)) .with_visible(conversion::visible(mode)); + if let Some(position) = conversion::position( + primary_monitor.as_ref(), + self.size, + self.position, + ) { + window_builder = window_builder.with_position(position); + } + if let Some((width, height)) = self.min_size { window_builder = window_builder .with_min_inner_size(winit::dpi::LogicalSize { width, height }); @@ -104,6 +114,9 @@ impl Window { .with_drag_and_drop(self.platform_specific.drag_and_drop); } + window_builder = window_builder + .with_fullscreen(conversion::fullscreen(primary_monitor, mode)); + window_builder } } @@ -112,6 +125,7 @@ impl Default for Window { fn default() -> Window { Window { size: (1024, 768), + position: Position::default(), min_size: None, max_size: None, resizable: true, |