summaryrefslogtreecommitdiffstats
path: root/winit/src/settings.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2021-07-22 17:49:18 +0700
committerLibravatar GitHub <noreply@github.com>2021-07-22 17:49:18 +0700
commit9cf5f3e1ef19f67b7939b9a747c2f66ad6b5275c (patch)
tree4c9af75c3a0b7d0d7a5e664ec55fbdbc24cd9f88 /winit/src/settings.rs
parent8fe8b6b168f193fadb495c78c076262d9114b14e (diff)
parent39b8f7de50ca53c67214c4ec2af2d3a0944f006a (diff)
downloadiced-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.rs18
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,