summaryrefslogtreecommitdiffstats
path: root/winit/src/conversion.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/conversion.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/conversion.rs')
-rw-r--r--winit/src/conversion.rs45
1 files changed, 44 insertions, 1 deletions
diff --git a/winit/src/conversion.rs b/winit/src/conversion.rs
index 5a8b9fd8..b3d05857 100644
--- a/winit/src/conversion.rs
+++ b/winit/src/conversion.rs
@@ -7,7 +7,7 @@ use crate::menu::{self, Menu};
use crate::mouse;
use crate::touch;
use crate::window;
-use crate::{Event, Mode, Point};
+use crate::{Event, Mode, Point, Position};
/// Converts a winit window event into an iced event.
pub fn window_event(
@@ -134,6 +134,49 @@ pub fn window_event(
}
}
+/// Converts a [`Position`] to a [`winit`] logical position for a given monitor.
+///
+/// [`winit`]: https://github.com/rust-windowing/winit
+pub fn position(
+ monitor: Option<&winit::monitor::MonitorHandle>,
+ (width, height): (u32, u32),
+ position: Position,
+) -> Option<winit::dpi::Position> {
+ match position {
+ Position::Default => None,
+ Position::Specific(x, y) => {
+ Some(winit::dpi::Position::Logical(winit::dpi::LogicalPosition {
+ x: f64::from(x),
+ y: f64::from(y),
+ }))
+ }
+ Position::Centered => {
+ if let Some(monitor) = monitor {
+ let start = monitor.position();
+
+ let resolution: winit::dpi::LogicalSize<f64> =
+ monitor.size().to_logical(monitor.scale_factor());
+
+ let centered: winit::dpi::PhysicalPosition<i32> =
+ winit::dpi::LogicalPosition {
+ x: (resolution.width - f64::from(width)) / 2.0,
+ y: (resolution.height - f64::from(height)) / 2.0,
+ }
+ .to_physical(monitor.scale_factor());
+
+ Some(winit::dpi::Position::Physical(
+ winit::dpi::PhysicalPosition {
+ x: start.x + centered.x,
+ y: start.y + centered.y,
+ },
+ ))
+ } else {
+ None
+ }
+ }
+ }
+}
+
/// Converts a [`Mode`] to a [`winit`] fullscreen mode.
///
/// [`winit`]: https://github.com/rust-windowing/winit