diff options
Diffstat (limited to '')
| -rw-r--r-- | core/src/window/settings.rs (renamed from src/window/settings.rs) | 73 |
1 files changed, 46 insertions, 27 deletions
diff --git a/src/window/settings.rs b/core/src/window/settings.rs index 0ee573e5..fbbf86ab 100644 --- a/src/window/settings.rs +++ b/core/src/window/settings.rs @@ -1,21 +1,47 @@ -use crate::window::{Icon, Level, Position}; +//! Configure your windows. +#[cfg(target_os = "windows")] +#[path = "settings/windows.rs"] +mod platform; + +#[cfg(target_os = "macos")] +#[path = "settings/macos.rs"] +mod platform; + +#[cfg(target_os = "linux")] +#[path = "settings/linux.rs"] +mod platform; + +#[cfg(target_arch = "wasm32")] +#[path = "settings/wasm.rs"] +mod platform; -pub use iced_winit::settings::PlatformSpecific; +#[cfg(not(any( + target_os = "windows", + target_os = "macos", + target_os = "linux", + target_arch = "wasm32" +)))] +#[path = "settings/other.rs"] +mod platform; +use crate::window::{Icon, Level, Position}; +use crate::Size; + +pub use platform::PlatformSpecific; /// The window settings of an application. #[derive(Debug, Clone)] pub struct Settings { - /// The initial size of the window. - pub size: (u32, u32), + /// The initial logical dimensions of the window. + pub size: Size, /// The initial position of the window. pub position: Position, /// The minimum size of the window. - pub min_size: Option<(u32, u32)>, + pub min_size: Option<Size>, /// The maximum size of the window. - pub max_size: Option<(u32, u32)>, + pub max_size: Option<Size>, /// Whether the window should be visible or not. pub visible: bool, @@ -37,12 +63,22 @@ pub struct Settings { /// Platform specific settings. pub platform_specific: PlatformSpecific, + + /// Whether the window will close when the user requests it, e.g. when a user presses the + /// close button. + /// + /// This can be useful if you want to have some behavior that executes before the window is + /// actually destroyed. If you disable this, you must manually close the window with the + /// `window::close` command. + /// + /// By default this is enabled. + pub exit_on_close_request: bool, } impl Default for Settings { - fn default() -> Settings { - Settings { - size: (1024, 768), + fn default() -> Self { + Self { + size: Size::new(1024.0, 768.0), position: Position::default(), min_size: None, max_size: None, @@ -52,25 +88,8 @@ impl Default for Settings { transparent: false, level: Level::default(), icon: None, + exit_on_close_request: true, platform_specific: PlatformSpecific::default(), } } } - -impl From<Settings> for iced_winit::settings::Window { - fn from(settings: Settings) -> Self { - Self { - size: settings.size, - position: iced_winit::Position::from(settings.position), - min_size: settings.min_size, - max_size: settings.max_size, - visible: settings.visible, - resizable: settings.resizable, - decorations: settings.decorations, - transparent: settings.transparent, - level: settings.level, - icon: settings.icon.map(Icon::into), - platform_specific: settings.platform_specific, - } - } -} |
