2019-02-05 10:30:33 -05:00
//! The `Window` struct and associated types.
2019-05-29 21:29:54 -04:00
use std ::fmt ;
2019-02-05 10:30:33 -05:00
2019-06-21 11:33:15 -04:00
use crate ::{
2019-06-19 16:49:43 -04:00
dpi ::{ PhysicalPosition , PhysicalSize , Position , Size } ,
2019-06-21 11:33:15 -04:00
error ::{ ExternalError , NotSupportedError , OsError } ,
event_loop ::EventLoopWindowTarget ,
2019-10-05 16:49:24 +02:00
monitor ::{ MonitorHandle , VideoMode } ,
2019-06-21 11:33:15 -04:00
platform_impl ,
} ;
2019-02-05 10:30:33 -05:00
2020-03-07 19:42:21 +00:00
pub use crate ::icon ::{ BadIcon , Icon } ;
2019-02-05 10:30:33 -05:00
/// Represents a window.
///
/// # Example
///
/// ```no_run
2019-06-21 11:33:15 -04:00
/// use winit::{
/// event::{Event, WindowEvent},
/// event_loop::{ControlFlow, EventLoop},
/// window::Window,
/// };
2019-02-05 10:30:33 -05:00
///
/// let mut event_loop = EventLoop::new();
/// let window = Window::new(&event_loop).unwrap();
///
/// event_loop.run(move |event, _, control_flow| {
2020-01-07 20:55:18 -07:00
/// *control_flow = ControlFlow::Wait;
///
2019-02-05 10:30:33 -05:00
/// match event {
2019-06-21 11:33:15 -04:00
/// Event::WindowEvent {
/// event: WindowEvent::CloseRequested,
/// ..
/// } => *control_flow = ControlFlow::Exit,
2020-01-07 20:55:18 -07:00
/// _ => (),
2019-02-05 10:30:33 -05:00
/// }
/// });
/// ```
pub struct Window {
pub ( crate ) window : platform_impl ::Window ,
}
impl fmt ::Debug for Window {
2019-06-18 02:27:00 +08:00
fn fmt ( & self , fmtr : & mut fmt ::Formatter < '_ > ) -> fmt ::Result {
2019-02-05 10:30:33 -05:00
fmtr . pad ( " Window { .. } " )
}
}
2019-07-29 21:16:14 +03:00
impl Drop for Window {
fn drop ( & mut self ) {
// If the window is in exclusive fullscreen, we must restore the desktop
// video mode (generally this would be done on application exit, but
// closing the window doesn't necessarily always mean application exit,
// such as when there are multiple windows)
if let Some ( Fullscreen ::Exclusive ( _ ) ) = self . fullscreen ( ) {
self . set_fullscreen ( None ) ;
}
}
}
2019-02-05 10:30:33 -05:00
/// Identifier of a window. Unique for each window.
///
/// Can be obtained with `window.id()`.
///
/// Whenever you receive an event specific to a window, this event contains a `WindowId` which you
/// can then compare to the ids of your windows.
#[ derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash) ]
pub struct WindowId ( pub ( crate ) platform_impl ::WindowId ) ;
impl WindowId {
2021-08-30 19:40:02 +02:00
/// Returns a dummy `WindowId`, useful for unit testing.
///
/// # Safety
///
/// The only guarantee made about the return value of this function is that
/// it will always be equal to itself and to future values returned by this function.
/// No other guarantees are made. This may be equal to a real `WindowId`.
2019-02-05 10:30:33 -05:00
///
/// **Passing this into a winit function will result in undefined behavior.**
2021-08-30 19:40:02 +02:00
pub const unsafe fn dummy ( ) -> Self {
2019-02-05 10:30:33 -05:00
WindowId ( platform_impl ::WindowId ::dummy ( ) )
}
}
2022-02-16 22:09:03 +01:00
/// Object that allows building windows.
2020-01-07 20:33:56 +01:00
#[ derive(Clone, Default) ]
2019-02-05 10:30:33 -05:00
pub struct WindowBuilder {
/// The attributes to use to create the window.
pub window : WindowAttributes ,
2019-06-28 21:32:27 +02:00
// Platform-specific configuration.
2019-02-05 10:30:33 -05:00
pub ( crate ) platform_specific : platform_impl ::PlatformSpecificWindowBuilderAttributes ,
}
impl fmt ::Debug for WindowBuilder {
2019-06-18 02:27:00 +08:00
fn fmt ( & self , fmtr : & mut fmt ::Formatter < '_ > ) -> fmt ::Result {
2019-02-05 10:30:33 -05:00
fmtr . debug_struct ( " WindowBuilder " )
. field ( " window " , & self . window )
. finish ( )
}
}
/// Attributes to use when creating a window.
#[ derive(Debug, Clone) ]
pub struct WindowAttributes {
/// The dimensions of the window. If this is `None`, some platform-specific dimensions will be
/// used.
///
/// The default is `None`.
2019-06-19 16:49:43 -04:00
pub inner_size : Option < Size > ,
2019-02-05 10:30:33 -05:00
/// The minimum dimensions a window can be, If this is `None`, the window will have no minimum dimensions (aside from reserved).
///
/// The default is `None`.
2019-06-19 16:49:43 -04:00
pub min_inner_size : Option < Size > ,
2015-02-16 09:29:37 +01:00
2019-02-05 10:30:33 -05:00
/// The maximum dimensions a window can be, If this is `None`, the maximum will have no maximum or will be set to the primary monitor's dimensions by the platform.
///
/// The default is `None`.
2019-06-19 16:49:43 -04:00
pub max_inner_size : Option < Size > ,
2019-02-05 10:30:33 -05:00
2021-03-25 21:18:51 +03:00
/// The desired position of the window. If this is `None`, some platform-specific position
/// will be chosen.
///
/// The default is `None`.
///
/// ## Platform-specific
///
/// - **macOS**: The top left corner position of the window content, the window's "inner"
/// position. The window title bar will be placed above it.
/// The window will be positioned such that it fits on screen, maintaining
/// set `inner_size` if any.
/// If you need to precisely position the top left corner of the whole window you have to
/// use [`Window::set_outer_position`] after creating the window.
/// - **Windows**: The top left corner position of the window title bar, the window's "outer"
/// position.
/// There may be a small gap between this position and the window due to the specifics of the
/// Window Manager.
/// - **X11**: The top left corner of the window, the window's "outer" position.
/// - **Others**: Ignored.
///
/// See [`Window::set_outer_position`].
///
/// [`Window::set_outer_position`]: crate::window::Window::set_outer_position
pub position : Option < Position > ,
2019-02-05 10:30:33 -05:00
/// Whether the window is resizable or not.
///
/// The default is `true`.
pub resizable : bool ,
/// Whether the window should be set as fullscreen upon creation.
///
/// The default is `None`.
2019-07-29 21:16:14 +03:00
pub fullscreen : Option < Fullscreen > ,
2019-02-05 10:30:33 -05:00
/// The title of the window in the title bar.
///
/// The default is `"winit window"`.
pub title : String ,
/// Whether the window should be maximized upon creation.
///
/// The default is `false`.
pub maximized : bool ,
/// Whether the window should be immediately visible upon creation.
///
/// The default is `true`.
pub visible : bool ,
/// Whether the the window should be transparent. If this is true, writing colors
/// with alpha values different than `1.0` will produce a transparent window.
///
/// The default is `false`.
pub transparent : bool ,
/// Whether the window should have borders and bars.
///
/// The default is `true`.
pub decorations : bool ,
/// Whether the window should always be on top of other windows.
///
/// The default is `false`.
pub always_on_top : bool ,
/// The window icon.
///
/// The default is `None`.
pub window_icon : Option < Icon > ,
}
impl Default for WindowAttributes {
#[ inline ]
fn default ( ) -> WindowAttributes {
WindowAttributes {
2019-05-29 21:29:54 -04:00
inner_size : None ,
min_inner_size : None ,
max_inner_size : None ,
2021-03-25 21:18:51 +03:00
position : None ,
2019-02-05 10:30:33 -05:00
resizable : true ,
title : " winit window " . to_owned ( ) ,
maximized : false ,
fullscreen : None ,
visible : true ,
transparent : false ,
decorations : true ,
always_on_top : false ,
window_icon : None ,
}
}
}
2019-09-24 00:10:33 +10:00
2016-02-23 12:56:23 +01:00
impl WindowBuilder {
2015-02-16 09:29:37 +01:00
/// Initializes a new `WindowBuilder` with default values.
2015-09-21 14:42:05 +02:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn new ( ) -> Self {
2020-01-07 20:33:56 +01:00
Default ::default ( )
2015-02-16 09:29:37 +01:00
}
/// Requests the window to be of specific dimensions.
2019-10-16 12:18:02 -04:00
///
/// See [`Window::set_inner_size`] for details.
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_inner_size`]: crate::window::Window::set_inner_size
2015-09-21 14:42:05 +02:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn with_inner_size < S : Into < Size > > ( mut self , size : S ) -> Self {
self . window . inner_size = Some ( size . into ( ) ) ;
2015-02-16 09:29:37 +01:00
self
}
2017-06-21 20:10:23 +01:00
2019-10-16 12:18:02 -04:00
/// Sets a minimum dimension size for the window.
///
/// See [`Window::set_min_inner_size`] for details.
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_min_inner_size`]: crate::window::Window::set_min_inner_size
2015-11-09 01:42:54 -08:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn with_min_inner_size < S : Into < Size > > ( mut self , min_size : S ) -> Self {
self . window . min_inner_size = Some ( min_size . into ( ) ) ;
2015-11-09 01:42:54 -08:00
self
}
2019-10-16 12:18:02 -04:00
/// Sets a maximum dimension size for the window.
///
/// See [`Window::set_max_inner_size`] for details.
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_max_inner_size`]: crate::window::Window::set_max_inner_size
2015-11-09 01:42:54 -08:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn with_max_inner_size < S : Into < Size > > ( mut self , max_size : S ) -> Self {
self . window . max_inner_size = Some ( max_size . into ( ) ) ;
2015-11-09 01:42:54 -08:00
self
}
2015-02-16 09:29:37 +01:00
2021-03-25 21:18:51 +03:00
/// Sets a desired initial position for the window.
///
/// See [`WindowAttributes::position`] for details.
///
/// [`WindowAttributes::position`]: crate::window::WindowAttributes::position
#[ inline ]
pub fn with_position < P : Into < Position > > ( mut self , position : P ) -> Self {
self . window . position = Some ( position . into ( ) ) ;
self
}
2019-10-16 12:18:02 -04:00
/// Sets whether the window is resizable or not.
2018-06-02 08:51:24 -06:00
///
2019-10-16 12:18:02 -04:00
/// See [`Window::set_resizable`] for details.
2018-06-11 16:47:50 -06:00
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_resizable`]: crate::window::Window::set_resizable
2018-06-02 08:51:24 -06:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn with_resizable ( mut self , resizable : bool ) -> Self {
2018-06-02 08:51:24 -06:00
self . window . resizable = resizable ;
self
}
2015-02-16 09:29:37 +01:00
/// Requests a specific title for the window.
2019-10-16 12:18:02 -04:00
///
/// See [`Window::set_title`] for details.
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_title`]: crate::window::Window::set_title
2015-09-21 14:42:05 +02:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn with_title < T : Into < String > > ( mut self , title : T ) -> Self {
2016-05-08 09:28:42 +02:00
self . window . title = title . into ( ) ;
2015-02-16 09:29:37 +01:00
self
}
2019-10-16 12:18:02 -04:00
/// Sets the window fullscreen state.
2019-07-29 11:18:23 +02:00
///
2019-10-16 12:18:02 -04:00
/// See [`Window::set_fullscreen`] for details.
2019-07-29 11:18:23 +02:00
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_fullscreen`]: crate::window::Window::set_fullscreen
2015-09-21 14:42:05 +02:00
#[ inline ]
2020-08-01 23:10:33 +00:00
pub fn with_fullscreen ( mut self , fullscreen : Option < Fullscreen > ) -> Self {
self . window . fullscreen = fullscreen ;
2015-02-16 09:29:37 +01:00
self
}
2017-08-28 00:19:26 +01:00
/// Requests maximized mode.
2019-10-16 12:18:02 -04:00
///
/// See [`Window::set_maximized`] for details.
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_maximized`]: crate::window::Window::set_maximized
2017-08-28 00:19:26 +01:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn with_maximized ( mut self , maximized : bool ) -> Self {
2017-08-28 00:19:26 +01:00
self . window . maximized = maximized ;
self
}
2015-02-16 09:29:37 +01:00
/// Sets whether the window will be initially hidden or visible.
2019-10-16 12:18:02 -04:00
///
/// See [`Window::set_visible`] for details.
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_visible`]: crate::window::Window::set_visible
2015-09-21 14:42:05 +02:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn with_visible ( mut self , visible : bool ) -> Self {
2015-09-21 13:15:43 +02:00
self . window . visible = visible ;
2015-02-16 09:29:37 +01:00
self
}
2015-05-15 15:19:33 +02:00
/// Sets whether the background of the window should be transparent.
2015-09-21 14:42:05 +02:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn with_transparent ( mut self , transparent : bool ) -> Self {
2015-09-21 13:15:43 +02:00
self . window . transparent = transparent ;
2015-05-15 15:19:33 +02:00
self
}
/// Sets whether the window should have a border, a title bar, etc.
2019-10-16 12:18:02 -04:00
///
/// See [`Window::set_decorations`] for details.
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_decorations`]: crate::window::Window::set_decorations
2015-09-21 14:42:05 +02:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn with_decorations ( mut self , decorations : bool ) -> Self {
2015-09-21 13:15:43 +02:00
self . window . decorations = decorations ;
2015-05-15 15:19:33 +02:00
self
}
2018-05-20 10:24:05 -04:00
/// Sets whether or not the window will always be on top of other windows.
2019-10-16 12:18:02 -04:00
///
/// See [`Window::set_always_on_top`] for details.
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_always_on_top`]: crate::window::Window::set_always_on_top
2018-05-20 10:24:05 -04:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn with_always_on_top ( mut self , always_on_top : bool ) -> Self {
2018-05-20 10:24:05 -04:00
self . window . always_on_top = always_on_top ;
self
}
2019-10-16 12:18:02 -04:00
/// Sets the window icon.
2018-05-07 17:36:21 -04:00
///
2019-10-16 12:18:02 -04:00
/// See [`Window::set_window_icon`] for details.
2018-05-07 17:36:21 -04:00
///
2019-11-11 18:05:59 -05:00
/// [`Window::set_window_icon`]: crate::window::Window::set_window_icon
2018-05-07 17:36:21 -04:00
#[ inline ]
2019-09-24 00:10:33 +10:00
pub fn with_window_icon ( mut self , window_icon : Option < Icon > ) -> Self {
2018-05-07 17:36:21 -04:00
self . window . window_icon = window_icon ;
self
}
2015-02-16 09:29:37 +01:00
/// Builds the window.
///
2019-06-22 01:35:08 +02:00
/// Possible causes of error include denied permission, incompatible system, and lack of memory.
2019-09-24 19:33:32 -04:00
///
/// Platform-specific behavior:
/// - **Web**: The window is created but not inserted into the web page automatically. Please
/// see the web platform module for more information.
2018-06-14 19:42:18 -04:00
#[ inline ]
2019-06-21 11:33:15 -04:00
pub fn build < T : 'static > (
2019-07-06 19:28:50 +02:00
self ,
2019-06-21 11:33:15 -04:00
window_target : & EventLoopWindowTarget < T > ,
) -> Result < Window , OsError > {
2019-10-17 10:59:07 -04:00
platform_impl ::Window ::new ( & window_target . p , self . window , self . platform_specific ) . map (
| window | {
window . request_redraw ( ) ;
Window { window }
} ,
)
2015-02-16 09:29:37 +01:00
}
}
2019-05-29 21:29:54 -04:00
/// Base Window functions.
2015-02-16 09:29:37 +01:00
impl Window {
2017-05-11 03:10:07 +03:00
/// Creates a new Window for platforms where this is appropriate.
2015-02-16 09:29:37 +01:00
///
2019-10-16 12:18:02 -04:00
/// This function is equivalent to [`WindowBuilder::new().build(event_loop)`].
2015-02-16 09:29:37 +01:00
///
/// Error should be very rare and only occur in case of permission denied, incompatible system,
/// out of memory, etc.
2019-10-16 12:18:02 -04:00
///
2019-09-24 19:33:32 -04:00
/// Platform-specific behavior:
/// - **Web**: The window is created but not inserted into the web page automatically. Please
/// see the web platform module for more information.
2019-10-16 16:09:39 -04:00
///
2019-11-11 18:05:59 -05:00
/// [`WindowBuilder::new().build(event_loop)`]: crate::window::WindowBuilder::build
2015-02-16 09:29:37 +01:00
#[ inline ]
2019-05-29 21:29:54 -04:00
pub fn new < T : 'static > ( event_loop : & EventLoopWindowTarget < T > ) -> Result < Window , OsError > {
2015-02-16 09:29:37 +01:00
let builder = WindowBuilder ::new ( ) ;
2019-02-05 10:30:33 -05:00
builder . build ( event_loop )
2015-02-16 09:29:37 +01:00
}
2019-05-29 21:29:54 -04:00
/// Returns an identifier unique to the window.
2015-02-16 09:29:37 +01:00
#[ inline ]
2019-05-29 21:29:54 -04:00
pub fn id ( & self ) -> WindowId {
WindowId ( self . window . id ( ) )
2015-02-16 09:29:37 +01:00
}
2020-01-03 14:52:27 -05:00
/// Returns the scale factor that can be used to map logical pixels to physical pixels, and vice versa.
2015-02-16 09:29:37 +01:00
///
2019-11-11 18:05:59 -05:00
/// See the [`dpi`](crate::dpi) module for more information.
2015-02-16 09:29:37 +01:00
///
2019-05-29 21:29:54 -04:00
/// Note that this value can change depending on user action (for example if the window is
2020-01-05 16:57:32 -05:00
/// moved to another screen); as such, tracking `WindowEvent::ScaleFactorChanged` events is
2019-05-29 21:29:54 -04:00
/// the most robust way to track the DPI you need to use to draw.
2015-02-16 09:29:37 +01:00
///
/// ## Platform-specific
///
2020-01-03 14:52:27 -05:00
/// - **X11:** This respects Xft.dpi, and can be overridden using the `WINIT_X11_SCALE_FACTOR` environment variable.
2019-05-29 21:29:54 -04:00
/// - **Android:** Always returns 1.0.
/// - **iOS:** Can only be called on the main thread. Returns the underlying `UIView`'s
/// [`contentScaleFactor`].
///
/// [`contentScaleFactor`]: https://developer.apple.com/documentation/uikit/uiview/1622657-contentscalefactor?language=objc
2015-02-16 09:29:37 +01:00
#[ inline ]
2020-01-03 14:52:27 -05:00
pub fn scale_factor ( & self ) -> f64 {
self . window . scale_factor ( )
2015-02-16 09:29:37 +01:00
}
2019-02-05 10:30:33 -05:00
/// Emits a `WindowEvent::RedrawRequested` event in the associated event loop after all OS
/// events have been processed by the event loop.
///
2019-06-18 00:22:01 +02:00
/// This is the **strongly encouraged** method of redrawing windows, as it can integrate with
2019-02-05 10:30:33 -05:00
/// OS-requested redraws (e.g. when a window gets resized).
///
2020-01-13 20:15:44 +01:00
/// This function can cause `RedrawRequested` events to be emitted after `Event::MainEventsCleared`
2019-02-05 10:30:33 -05:00
/// but before `Event::NewEvents` if called in the following circumstances:
2020-01-13 20:15:44 +01:00
/// * While processing `MainEventsCleared`.
/// * While processing a `RedrawRequested` event that was sent during `MainEventsCleared` or any
2019-02-05 10:30:33 -05:00
/// directly subsequent `RedrawRequested` event.
2019-05-25 18:10:41 -07:00
///
/// ## Platform-specific
///
/// - **iOS:** Can only be called on the main thread.
2021-06-05 12:47:08 +02:00
/// - **Android:** Subsequent calls after `MainEventsCleared` are not handled.
2019-05-29 21:29:54 -04:00
#[ inline ]
2019-02-05 10:30:33 -05:00
pub fn request_redraw ( & self ) {
self . window . request_redraw ( )
}
2019-05-29 21:29:54 -04:00
}
/// Position and size functions.
impl Window {
/// Returns the position of the top-left hand corner of the window's client area relative to the
/// top-left hand corner of the desktop.
///
/// The same conditions that apply to `outer_position` apply to this method.
///
/// ## Platform-specific
///
/// - **iOS:** Can only be called on the main thread. Returns the top left coordinates of the
/// window's [safe area] in the screen space coordinate system.
2019-12-31 14:39:33 -08:00
/// - **Web:** Returns the top-left coordinates relative to the viewport. _Note: this returns the
/// same value as `outer_position`._
2020-07-26 21:13:17 +00:00
/// - **Android / Wayland:** Always returns [`NotSupportedError`].
2019-05-29 21:29:54 -04:00
///
/// [safe area]: https://developer.apple.com/documentation/uikit/uiview/2891103-safeareainsets?language=objc
#[ inline ]
2020-01-04 01:33:07 -05:00
pub fn inner_position ( & self ) -> Result < PhysicalPosition < i32 > , NotSupportedError > {
2019-05-29 21:29:54 -04:00
self . window . inner_position ( )
}
2019-02-05 10:30:33 -05:00
2015-02-16 09:29:37 +01:00
/// Returns the position of the top-left hand corner of the window relative to the
/// top-left hand corner of the desktop.
///
2015-03-25 23:44:21 -04:00
/// Note that the top-left hand corner of the desktop is not necessarily the same as
2015-02-16 09:29:37 +01:00
/// the screen. If the user uses a desktop with multiple monitors, the top-left hand corner
/// of the desktop is the top-left hand corner of the monitor at the top-left of the desktop.
///
/// The coordinates can be negative if the top-left hand corner of the window is outside
/// of the visible screen region.
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
/// - **iOS:** Can only be called on the main thread. Returns the top left coordinates of the
/// window in the screen space coordinate system.
2019-12-31 14:39:33 -08:00
/// - **Web:** Returns the top-left coordinates relative to the viewport.
2020-07-26 21:13:17 +00:00
/// - **Android / Wayland:** Always returns [`NotSupportedError`].
2015-02-16 09:29:37 +01:00
#[ inline ]
2020-01-04 01:33:07 -05:00
pub fn outer_position ( & self ) -> Result < PhysicalPosition < i32 > , NotSupportedError > {
2019-05-29 21:29:54 -04:00
self . window . outer_position ( )
2018-04-16 21:40:30 -04:00
}
2015-02-16 09:29:37 +01:00
/// Modifies the position of the window.
///
2019-08-26 22:07:15 -04:00
/// See `outer_position` for more information about the coordinates. This automatically un-maximizes the
/// window if it's maximized.
2015-02-16 09:29:37 +01:00
///
2022-01-02 14:56:13 +11:00
/// ```no_run
/// # use winit::dpi::{LogicalPosition, PhysicalPosition};
/// # use winit::event_loop::EventLoop;
/// # use winit::window::Window;
/// # let mut event_loop = EventLoop::new();
/// # let window = Window::new(&event_loop).unwrap();
/// // Specify the position in logical dimensions like this:
/// window.set_outer_position(LogicalPosition::new(400.0, 200.0));
///
/// // Or specify the position in physical dimensions like this:
/// window.set_outer_position(PhysicalPosition::new(400, 200));
/// ```
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
/// - **iOS:** Can only be called on the main thread. Sets the top left coordinates of the
/// window in the screen space coordinate system.
2019-12-31 14:39:33 -08:00
/// - **Web:** Sets the top-left coordinates relative to the viewport.
2020-07-26 21:13:17 +00:00
/// - **Android / Wayland:** Unsupported.
2015-02-16 09:29:37 +01:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn set_outer_position < P : Into < Position > > ( & self , position : P ) {
self . window . set_outer_position ( position . into ( ) )
2015-02-16 09:29:37 +01:00
}
2020-01-04 01:31:23 -05:00
/// Returns the physical size of the window's client area.
2015-07-25 13:57:52 +02:00
///
/// The client area is the content of the window, excluding the title bar and borders.
2015-02-16 09:29:37 +01:00
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
2019-06-19 16:49:43 -04:00
/// - **iOS:** Can only be called on the main thread. Returns the `PhysicalSize` of the window's
2019-05-25 18:10:41 -07:00
/// [safe area] in screen space coordinates.
2019-12-31 14:39:33 -08:00
/// - **Web:** Returns the size of the canvas element.
2019-05-25 18:10:41 -07:00
///
2019-05-29 21:29:54 -04:00
/// [safe area]: https://developer.apple.com/documentation/uikit/uiview/2891103-safeareainsets?language=objc
2015-02-16 09:29:37 +01:00
#[ inline ]
2020-01-04 01:33:07 -05:00
pub fn inner_size ( & self ) -> PhysicalSize < u32 > {
2019-05-29 21:29:54 -04:00
self . window . inner_size ( )
2015-02-16 09:29:37 +01:00
}
/// Modifies the inner size of the window.
///
2019-08-26 22:07:15 -04:00
/// See `inner_size` for more information about the values. This automatically un-maximizes the
/// window if it's maximized.
2019-05-25 18:10:41 -07:00
///
2022-01-02 14:56:13 +11:00
/// ```no_run
/// # use winit::dpi::{LogicalSize, PhysicalSize};
/// # use winit::event_loop::EventLoop;
/// # use winit::window::Window;
/// # let mut event_loop = EventLoop::new();
/// # let window = Window::new(&event_loop).unwrap();
/// // Specify the size in logical dimensions like this:
/// window.set_inner_size(LogicalSize::new(400.0, 200.0));
///
/// // Or specify the size in physical dimensions like this:
/// window.set_inner_size(PhysicalSize::new(400, 200));
/// ```
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android:** Unsupported.
2019-12-31 14:39:33 -08:00
/// - **Web:** Sets the size of the canvas element.
2015-02-16 09:29:37 +01:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn set_inner_size < S : Into < Size > > ( & self , size : S ) {
self . window . set_inner_size ( size . into ( ) )
2015-02-16 09:29:37 +01:00
}
2020-01-04 01:31:23 -05:00
/// Returns the physical size of the entire window.
2019-05-29 21:29:54 -04:00
///
/// These dimensions include the title bar and borders. If you don't want that (and you usually don't),
/// use `inner_size` instead.
2019-05-25 18:10:41 -07:00
///
/// ## Platform-specific
///
2019-06-19 16:49:43 -04:00
/// - **iOS:** Can only be called on the main thread. Returns the `PhysicalSize` of the window in
2019-05-29 21:29:54 -04:00
/// screen space coordinates.
2019-12-31 14:39:33 -08:00
/// - **Web:** Returns the size of the canvas element. _Note: this returns the same value as
/// `inner_size`._
2018-03-23 05:35:35 -04:00
#[ inline ]
2020-01-04 01:33:07 -05:00
pub fn outer_size ( & self ) -> PhysicalSize < u32 > {
2019-05-29 21:29:54 -04:00
self . window . outer_size ( )
2018-03-23 05:35:35 -04:00
}
2019-05-29 21:29:54 -04:00
/// Sets a minimum dimension size for the window.
2019-05-25 18:10:41 -07:00
///
2022-01-02 14:56:13 +11:00
/// ```no_run
/// # use winit::dpi::{LogicalSize, PhysicalSize};
/// # use winit::event_loop::EventLoop;
/// # use winit::window::Window;
/// # let mut event_loop = EventLoop::new();
/// # let window = Window::new(&event_loop).unwrap();
/// // Specify the size in logical dimensions like this:
/// window.set_min_inner_size(Some(LogicalSize::new(400.0, 200.0)));
///
/// // Or specify the size in physical dimensions like this:
/// window.set_min_inner_size(Some(PhysicalSize::new(400, 200)));
/// ```
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android / Web:** Unsupported.
2018-03-23 05:35:35 -04:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn set_min_inner_size < S : Into < Size > > ( & self , min_size : Option < S > ) {
self . window . set_min_inner_size ( min_size . map ( | s | s . into ( ) ) )
2018-03-23 05:35:35 -04:00
}
2019-05-29 21:29:54 -04:00
/// Sets a maximum dimension size for the window.
2019-05-25 18:10:41 -07:00
///
2022-01-02 14:56:13 +11:00
/// ```no_run
/// # use winit::dpi::{LogicalSize, PhysicalSize};
/// # use winit::event_loop::EventLoop;
/// # use winit::window::Window;
/// # let mut event_loop = EventLoop::new();
/// # let window = Window::new(&event_loop).unwrap();
/// // Specify the size in logical dimensions like this:
/// window.set_max_inner_size(Some(LogicalSize::new(400.0, 200.0)));
///
/// // Or specify the size in physical dimensions like this:
/// window.set_max_inner_size(Some(PhysicalSize::new(400, 200)));
/// ```
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
2021-02-27 14:25:26 -06:00
/// - **iOS / Android / Web:** Unsupported.
2018-06-11 16:47:50 -06:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn set_max_inner_size < S : Into < Size > > ( & self , max_size : Option < S > ) {
self . window . set_max_inner_size ( max_size . map ( | s | s . into ( ) ) )
2018-06-11 16:47:50 -06:00
}
2019-05-29 21:29:54 -04:00
}
2018-06-11 16:47:50 -06:00
2019-05-29 21:29:54 -04:00
/// Misc. attribute functions.
impl Window {
/// Modifies the title of the window.
2018-07-16 16:44:29 +02:00
///
2018-06-14 19:42:18 -04:00
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android:** Unsupported.
2015-02-20 12:32:40 -08:00
#[ inline ]
2019-05-29 21:29:54 -04:00
pub fn set_title ( & self , title : & str ) {
self . window . set_title ( title )
2015-02-20 12:32:40 -08:00
}
2019-05-29 21:29:54 -04:00
/// Modifies the window's visibility.
2019-05-25 18:10:41 -07:00
///
2019-05-29 21:29:54 -04:00
/// If `false`, this will hide the window. If `true`, this will show the window.
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **Android / Wayland / Web:** Unsupported.
2019-05-29 21:29:54 -04:00
/// - **iOS:** Can only be called on the main thread.
2018-06-14 19:42:18 -04:00
#[ inline ]
2019-05-29 21:29:54 -04:00
pub fn set_visible ( & self , visible : bool ) {
self . window . set_visible ( visible )
2015-02-16 09:29:37 +01:00
}
2019-05-29 21:29:54 -04:00
/// Sets whether the window is resizable or not.
2019-05-25 18:10:41 -07:00
///
2019-05-29 21:29:54 -04:00
/// Note that making the window unresizable doesn't exempt you from handling `Resized`, as that event can still be
/// triggered by DPI scaling, entering fullscreen mode, etc.
2015-03-26 17:04:01 +01:00
///
2018-06-18 12:32:18 -04:00
/// ## Platform-specific
///
2019-05-29 21:29:54 -04:00
/// This only has an effect on desktop platforms.
///
/// Due to a bug in XFCE, this has no effect on Xfwm.
2018-06-18 12:32:18 -04:00
///
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android / Web:** Unsupported.
2015-09-21 14:42:05 +02:00
#[ inline ]
2019-05-29 21:29:54 -04:00
pub fn set_resizable ( & self , resizable : bool ) {
self . window . set_resizable ( resizable )
2015-01-25 12:06:50 +01:00
}
2017-01-28 15:05:36 +01:00
2019-12-22 01:04:11 -05:00
/// Sets the window to minimized or back
///
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android / Web:** Unsupported.
/// - **Wayland:** Un-minimize is unsupported.
2019-12-22 01:04:11 -05:00
#[ inline ]
pub fn set_minimized ( & self , minimized : bool ) {
self . window . set_minimized ( minimized ) ;
}
2019-05-25 18:10:41 -07:00
/// Sets the window to maximized or back.
///
/// ## Platform-specific
2019-05-29 21:29:54 -04:00
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android / Web:** Unsupported.
2017-08-28 00:19:26 +01:00
#[ inline ]
pub fn set_maximized ( & self , maximized : bool ) {
self . window . set_maximized ( maximized )
}
2021-01-27 20:01:17 +02:00
/// Gets the window's current maximized state.
///
/// ## Platform-specific
///
/// - **Wayland / X11:** Not implemented.
/// - **iOS / Android / Web:** Unsupported.
#[ inline ]
pub fn is_maximized ( & self ) -> bool {
self . window . is_maximized ( )
}
2019-05-25 18:10:41 -07:00
/// Sets the window to fullscreen or back.
///
/// ## Platform-specific
2019-05-29 21:29:54 -04:00
///
2019-07-29 21:16:14 +03:00
/// - **macOS:** `Fullscreen::Exclusive` provides true exclusive mode with a
/// video mode change. *Caveat!* macOS doesn't provide task switching (or
/// spaces!) while in exclusive fullscreen mode. This mode should be used
/// when a video mode change is desired, but for a better user experience,
/// borderless fullscreen might be preferred.
///
/// `Fullscreen::Borderless` provides a borderless fullscreen window on a
/// separate space. This is the idiomatic way for fullscreen games to work
2019-11-11 18:05:59 -05:00
/// on macOS. See `WindowExtMacOs::set_simple_fullscreen` if
2019-07-29 21:16:14 +03:00
/// separate spaces are not preferred.
///
/// The dock and the menu bar are always disabled in fullscreen mode.
2019-05-25 18:10:41 -07:00
/// - **iOS:** Can only be called on the main thread.
Update SCTK to 0.11.0
* Update SCTK to 0.11.0
Updates smithay-client-toolkit to 0.11.0. The major highlight
of that updated, is update of wayland-rs to 0.27.0. Switching
to wayland-cursor, instead of using libwayland-cursor. It
also fixes the following bugs:
- Disabled repeat rate not being handled.
- Decoration buttons not working after tty switch.
- Scaling not being applied on output reenable.
- Crash when `XCURSOR_SIZE` is `0`.
- Pointer getting created in some cases without pointer capability.
- On kwin, fix space between window and decorations on startup.
- Incorrect size event when entering fullscreen when using
client side decorations.
- Client side decorations not being hided properly in fullscreen.
- Size tracking between fullscreen/tiled state changes.
- Repeat rate triggering multiple times from slow callback handler.
- Resizable attribute not being applied properly on startup.
- Not working IME
Besides those fixes it also adds a bunch of missing virtual key codes,
implements proper cursor grabbing, adds right click on decorations
to open application menu, disabled maximize button for non-resizeable
window, and fall back for cursor icon to similar ones, if the requested
is missing.
It also adds new methods to a `Theme` trait, such as:
- `title_font(&self) -> Option<(String, f32)>` - The font for a title.
- `title_color(&self, window_active: bool) -> [u8; 4]` - The color of
the text in the title.
Fixes #1680.
Fixes #1678.
Fixes #1676.
Fixes #1646.
Fixes #1614.
Fixes #1601.
Fixes #1533.
Fixes #1509.
Fixes #952.
Fixes #947.
2020-09-29 00:11:43 +03:00
/// - **Wayland:** Does not support exclusive fullscreen mode and will no-op a request.
2019-07-29 11:18:23 +02:00
/// - **Windows:** Screen saver is disabled in fullscreen mode.
2020-07-26 21:13:17 +00:00
/// - **Android:** Unsupported.
2017-08-28 00:22:26 +01:00
#[ inline ]
2019-07-29 21:16:14 +03:00
pub fn set_fullscreen ( & self , fullscreen : Option < Fullscreen > ) {
self . window . set_fullscreen ( fullscreen )
2017-09-07 09:33:46 +01:00
}
2019-04-26 03:09:32 +10:00
/// Gets the window's current fullscreen state.
2019-05-25 18:10:41 -07:00
///
/// ## Platform-specific
2019-05-29 21:29:54 -04:00
///
2019-05-25 18:10:41 -07:00
/// - **iOS:** Can only be called on the main thread.
2020-07-26 21:13:17 +00:00
/// - **Android:** Will always return `None`.
2020-09-22 04:54:47 +03:00
/// - **Wayland:** Can return `Borderless(None)` when there are no monitors.
2019-04-26 03:09:32 +10:00
#[ inline ]
2019-07-29 21:16:14 +03:00
pub fn fullscreen ( & self ) -> Option < Fullscreen > {
2019-05-29 21:29:54 -04:00
self . window . fullscreen ( )
2019-04-26 03:09:32 +10:00
}
2017-12-22 07:50:46 -05:00
/// Turn window decorations on or off.
2019-05-25 18:10:41 -07:00
///
/// ## Platform-specific
2020-07-26 21:13:17 +00:00
///
/// - **iOS / Android / Web:** Unsupported.
2019-05-29 21:29:54 -04:00
///
2019-05-25 18:10:41 -07:00
/// [`setPrefersStatusBarHidden`]: https://developer.apple.com/documentation/uikit/uiviewcontroller/1621440-prefersstatusbarhidden?language=objc
2017-12-22 07:50:46 -05:00
#[ inline ]
pub fn set_decorations ( & self , decorations : bool ) {
self . window . set_decorations ( decorations )
}
2018-05-20 10:24:05 -04:00
/// Change whether or not the window will always be on top of other windows.
2019-05-25 18:10:41 -07:00
///
/// ## Platform-specific
2019-05-29 21:29:54 -04:00
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android / Web / Wayland:** Unsupported.
2018-05-20 10:24:05 -04:00
#[ inline ]
pub fn set_always_on_top ( & self , always_on_top : bool ) {
self . window . set_always_on_top ( always_on_top )
}
2018-05-07 17:36:21 -04:00
/// Sets the window icon. On Windows and X11, this is typically the small icon in the top-left
/// corner of the titlebar.
///
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android / Web / Wayland / macOS:** Unsupported.
2019-10-16 12:18:02 -04:00
///
/// On Windows, this sets `ICON_SMALL`. The base size for a window icon is 16x16, but it's
/// recommended to account for screen scaling and pick a multiple of that, i.e. 32x32.
///
/// X11 has no universal guidelines for icon sizes, so you're at the whims of the WM. That
/// said, it's usually in the same ballpark as on Windows.
2018-05-07 17:36:21 -04:00
#[ inline ]
pub fn set_window_icon ( & self , window_icon : Option < Icon > ) {
self . window . set_window_icon ( window_icon )
}
2018-05-20 10:47:22 -04:00
/// Sets location of IME candidate box in client area coordinates relative to the top left.
2019-05-25 18:10:41 -07:00
///
2022-01-02 14:56:13 +11:00
/// ```no_run
/// # use winit::dpi::{LogicalPosition, PhysicalPosition};
/// # use winit::event_loop::EventLoop;
/// # use winit::window::Window;
/// # let mut event_loop = EventLoop::new();
/// # let window = Window::new(&event_loop).unwrap();
/// // Specify the position in logical dimensions like this:
/// window.set_ime_position(LogicalPosition::new(400.0, 200.0));
///
/// // Or specify the position in physical dimensions like this:
/// window.set_ime_position(PhysicalPosition::new(400, 200));
/// ```
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
2020-12-10 05:16:59 +09:00
/// - **iOS / Android / Web:** Unsupported.
2018-05-17 21:28:30 -04:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn set_ime_position < P : Into < Position > > ( & self , position : P ) {
self . window . set_ime_position ( position . into ( ) )
2018-05-17 21:28:30 -04:00
}
2020-11-27 03:03:08 +01:00
2021-05-19 18:39:53 +02:00
/// Brings the window to the front and sets input focus. Has no effect if the window is
/// already in focus, minimized, or not visible.
///
/// This method steals input focus from other applications. Do not use this method unless
/// you are certain that's what the user wants. Focus stealing can cause an extremely disruptive
/// user experience.
///
/// ## Platform-specific
///
/// - **iOS / Android / Web / Wayland:** Unsupported.
#[ inline ]
pub fn focus_window ( & self ) {
self . window . focus_window ( )
}
2020-11-27 03:03:08 +01:00
/// Requests user attention to the window, this has no effect if the application
/// is already focused. How requesting for user attention manifests is platform dependent,
/// see `UserAttentionType` for details.
///
/// Providing `None` will unset the request for user attention. Unsetting the request for
/// user attention might not be done automatically by the WM when the window receives input.
///
/// ## Platform-specific
///
2021-08-17 07:59:57 +03:00
/// - **iOS / Android / Web :** Unsupported.
2020-11-27 03:03:08 +01:00
/// - **macOS:** `None` has no effect.
/// - **X11:** Requests for user attention must be manually cleared.
2021-08-17 07:59:57 +03:00
/// - **Wayland:** Requires `xdg_activation_v1` protocol, `None` has no effect.
2020-11-27 03:03:08 +01:00
#[ inline ]
pub fn request_user_attention ( & self , request_type : Option < UserAttentionType > ) {
self . window . request_user_attention ( request_type )
}
2019-05-29 21:29:54 -04:00
}
2018-05-17 21:28:30 -04:00
2019-05-29 21:29:54 -04:00
/// Cursor functions.
impl Window {
/// Modifies the cursor icon of the window.
2019-05-25 18:10:41 -07:00
///
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android:** Unsupported.
2018-06-14 19:42:18 -04:00
#[ inline ]
2019-05-29 21:29:54 -04:00
pub fn set_cursor_icon ( & self , cursor : CursorIcon ) {
self . window . set_cursor_icon ( cursor ) ;
2017-08-28 00:22:26 +01:00
}
2019-05-29 21:29:54 -04:00
/// Changes the position of the cursor in window coordinates.
2019-05-25 18:10:41 -07:00
///
2022-01-02 14:56:13 +11:00
/// ```no_run
/// # use winit::dpi::{LogicalPosition, PhysicalPosition};
/// # use winit::event_loop::EventLoop;
/// # use winit::window::Window;
/// # let mut event_loop = EventLoop::new();
/// # let window = Window::new(&event_loop).unwrap();
/// // Specify the position in logical dimensions like this:
/// window.set_cursor_position(LogicalPosition::new(400.0, 200.0));
///
/// // Or specify the position in physical dimensions like this:
/// window.set_cursor_position(PhysicalPosition::new(400, 200));
/// ```
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
2020-07-26 21:13:17 +00:00
/// - **iOS / Android / Web / Wayland:** Always returns an [`ExternalError::NotSupported`].
2018-06-16 10:14:12 -04:00
#[ inline ]
2019-06-19 16:49:43 -04:00
pub fn set_cursor_position < P : Into < Position > > ( & self , position : P ) -> Result < ( ) , ExternalError > {
self . window . set_cursor_position ( position . into ( ) )
2018-06-16 10:14:12 -04:00
}
2019-05-29 21:29:54 -04:00
/// Grabs the cursor, preventing it from leaving the window.
2019-05-25 18:10:41 -07:00
///
Update SCTK to 0.11.0
* Update SCTK to 0.11.0
Updates smithay-client-toolkit to 0.11.0. The major highlight
of that updated, is update of wayland-rs to 0.27.0. Switching
to wayland-cursor, instead of using libwayland-cursor. It
also fixes the following bugs:
- Disabled repeat rate not being handled.
- Decoration buttons not working after tty switch.
- Scaling not being applied on output reenable.
- Crash when `XCURSOR_SIZE` is `0`.
- Pointer getting created in some cases without pointer capability.
- On kwin, fix space between window and decorations on startup.
- Incorrect size event when entering fullscreen when using
client side decorations.
- Client side decorations not being hided properly in fullscreen.
- Size tracking between fullscreen/tiled state changes.
- Repeat rate triggering multiple times from slow callback handler.
- Resizable attribute not being applied properly on startup.
- Not working IME
Besides those fixes it also adds a bunch of missing virtual key codes,
implements proper cursor grabbing, adds right click on decorations
to open application menu, disabled maximize button for non-resizeable
window, and fall back for cursor icon to similar ones, if the requested
is missing.
It also adds new methods to a `Theme` trait, such as:
- `title_font(&self) -> Option<(String, f32)>` - The font for a title.
- `title_color(&self, window_active: bool) -> [u8; 4]` - The color of
the text in the title.
Fixes #1680.
Fixes #1678.
Fixes #1676.
Fixes #1646.
Fixes #1614.
Fixes #1601.
Fixes #1533.
Fixes #1509.
Fixes #952.
Fixes #947.
2020-09-29 00:11:43 +03:00
/// There's no guarantee that the cursor will be hidden. You should
/// hide it by yourself if you want so.
///
2019-05-25 18:10:41 -07:00
/// ## Platform-specific
///
Update SCTK to 0.11.0
* Update SCTK to 0.11.0
Updates smithay-client-toolkit to 0.11.0. The major highlight
of that updated, is update of wayland-rs to 0.27.0. Switching
to wayland-cursor, instead of using libwayland-cursor. It
also fixes the following bugs:
- Disabled repeat rate not being handled.
- Decoration buttons not working after tty switch.
- Scaling not being applied on output reenable.
- Crash when `XCURSOR_SIZE` is `0`.
- Pointer getting created in some cases without pointer capability.
- On kwin, fix space between window and decorations on startup.
- Incorrect size event when entering fullscreen when using
client side decorations.
- Client side decorations not being hided properly in fullscreen.
- Size tracking between fullscreen/tiled state changes.
- Repeat rate triggering multiple times from slow callback handler.
- Resizable attribute not being applied properly on startup.
- Not working IME
Besides those fixes it also adds a bunch of missing virtual key codes,
implements proper cursor grabbing, adds right click on decorations
to open application menu, disabled maximize button for non-resizeable
window, and fall back for cursor icon to similar ones, if the requested
is missing.
It also adds new methods to a `Theme` trait, such as:
- `title_font(&self) -> Option<(String, f32)>` - The font for a title.
- `title_color(&self, window_active: bool) -> [u8; 4]` - The color of
the text in the title.
Fixes #1680.
Fixes #1678.
Fixes #1676.
Fixes #1646.
Fixes #1614.
Fixes #1601.
Fixes #1533.
Fixes #1509.
Fixes #952.
Fixes #947.
2020-09-29 00:11:43 +03:00
/// - **macOS:** This locks the cursor in a fixed location, which looks visually awkward.
2022-01-05 11:13:46 +01:00
/// - **iOS / Android:** Always returns an [`ExternalError::NotSupported`].
2018-06-16 10:14:12 -04:00
#[ inline ]
2019-05-29 21:29:54 -04:00
pub fn set_cursor_grab ( & self , grab : bool ) -> Result < ( ) , ExternalError > {
self . window . set_cursor_grab ( grab )
2018-06-16 10:14:12 -04:00
}
2019-06-02 00:06:41 +00:00
/// Modifies the cursor's visibility.
///
/// If `false`, this will hide the cursor. If `true`, this will show the cursor.
2019-05-29 21:29:54 -04:00
///
/// ## Platform-specific
///
/// - **Windows:** The cursor is only hidden within the confines of the window.
/// - **X11:** The cursor is only hidden within the confines of the window.
2019-10-02 03:25:59 +02:00
/// - **Wayland:** The cursor is only hidden within the confines of the window.
2019-05-29 21:29:54 -04:00
/// - **macOS:** The cursor is hidden as long as the window has input focus, even if the cursor is
/// outside of the window.
2020-07-26 21:13:17 +00:00
/// - **iOS / Android:** Unsupported.
2017-01-28 15:05:36 +01:00
#[ inline ]
2019-05-29 21:29:54 -04:00
pub fn set_cursor_visible ( & self , visible : bool ) {
self . window . set_cursor_visible ( visible )
2017-01-28 15:05:36 +01:00
}
2021-03-07 10:43:23 +01:00
/// Moves the window with the left mouse button until the button is released.
///
/// There's no guarantee that this will work unless the left mouse button was pressed
/// immediately before this function is called.
///
/// ## Platform-specific
///
/// - **X11:** Un-grabs the cursor.
/// - **Wayland:** Requires the cursor to be inside the window to be dragged.
/// - **macOS:** May prevent the button release event to be triggered.
/// - **iOS / Android / Web:** Always returns an [`ExternalError::NotSupported`].
#[ inline ]
pub fn drag_window ( & self ) -> Result < ( ) , ExternalError > {
self . window . drag_window ( )
}
2015-02-16 09:29:37 +01:00
}
2019-05-29 21:29:54 -04:00
/// Monitor info functions.
impl Window {
2020-09-07 20:09:24 +03:00
/// Returns the monitor on which the window currently resides.
///
/// Returns `None` if current monitor can't be detected.
2019-05-29 21:29:54 -04:00
///
/// ## Platform-specific
///
/// **iOS:** Can only be called on the main thread.
#[ inline ]
2020-09-07 20:09:24 +03:00
pub fn current_monitor ( & self ) -> Option < MonitorHandle > {
2019-05-29 21:29:54 -04:00
self . window . current_monitor ( )
2015-03-16 13:50:23 +01:00
}
2015-02-16 09:29:37 +01:00
2019-05-29 21:29:54 -04:00
/// Returns the list of all the monitors available on the system.
///
2020-07-04 15:46:41 -04:00
/// This is the same as `EventLoopWindowTarget::available_monitors`, and is provided for convenience.
2019-05-29 21:29:54 -04:00
///
/// ## Platform-specific
///
/// **iOS:** Can only be called on the main thread.
#[ inline ]
2019-10-05 16:49:24 +02:00
pub fn available_monitors ( & self ) -> impl Iterator < Item = MonitorHandle > {
self . window
. available_monitors ( )
. into_iter ( )
. map ( | inner | MonitorHandle { inner } )
2015-03-16 13:52:58 -07:00
}
2019-05-29 21:29:54 -04:00
/// Returns the primary monitor of the system.
///
2020-09-07 20:20:47 +03:00
/// Returns `None` if it can't identify any monitor as a primary one.
///
2020-07-04 15:46:41 -04:00
/// This is the same as `EventLoopWindowTarget::primary_monitor`, and is provided for convenience.
2019-05-29 21:29:54 -04:00
///
/// ## Platform-specific
///
/// **iOS:** Can only be called on the main thread.
2020-09-07 20:20:47 +03:00
/// **Wayland:** Always returns `None`.
2019-05-29 21:29:54 -04:00
#[ inline ]
2020-09-07 20:20:47 +03:00
pub fn primary_monitor ( & self ) -> Option < MonitorHandle > {
self . window . primary_monitor ( )
2015-02-16 09:29:37 +01:00
}
2019-02-05 10:30:33 -05:00
}
2017-09-07 09:33:46 +01:00
2019-08-14 07:57:16 -04:00
unsafe impl raw_window_handle ::HasRawWindowHandle for Window {
2020-10-29 16:23:46 -05:00
/// Returns a `raw_window_handle::RawWindowHandle` for the Window
///
/// ## Platform-specific
///
/// - **Android:** Only available after receiving the Resumed event and before Suspended. *If you*
/// *try to get the handle outside of that period, this function will panic*!
2019-08-14 07:57:16 -04:00
fn raw_window_handle ( & self ) -> raw_window_handle ::RawWindowHandle {
self . window . raw_window_handle ( )
}
}
2019-02-05 10:30:33 -05:00
/// Describes the appearance of the mouse cursor.
#[ derive(Debug, Copy, Clone, PartialEq, Eq, Hash) ]
#[ cfg_attr(feature = " serde " , derive(Serialize, Deserialize)) ]
2019-05-29 21:29:54 -04:00
pub enum CursorIcon {
2019-02-05 10:30:33 -05:00
/// The platform-dependent default cursor.
Default ,
/// A simple crosshair.
Crosshair ,
/// A hand (often used to indicate links in web browsers).
Hand ,
/// Self explanatory.
Arrow ,
/// Indicates something is to be moved.
Move ,
/// Indicates text that may be selected or edited.
Text ,
/// Program busy indicator.
Wait ,
/// Help indicator (often rendered as a "?")
Help ,
/// Progress indicator. Shows that processing is being done. But in contrast
/// with "Wait" the user may still interact with the program. Often rendered
/// as a spinning beach ball, or an arrow with a watch or hourglass.
Progress ,
/// Cursor showing that something cannot be done.
NotAllowed ,
ContextMenu ,
Cell ,
VerticalText ,
Alias ,
Copy ,
NoDrop ,
2019-09-12 18:38:44 -05:00
/// Indicates something can be grabbed.
2019-02-05 10:30:33 -05:00
Grab ,
2019-09-12 18:38:44 -05:00
/// Indicates something is grabbed.
2019-02-05 10:30:33 -05:00
Grabbing ,
AllScroll ,
ZoomIn ,
ZoomOut ,
/// Indicate that some edge is to be moved. For example, the 'SeResize' cursor
/// is used when the movement starts from the south-east corner of the box.
EResize ,
NResize ,
NeResize ,
NwResize ,
SResize ,
SeResize ,
SwResize ,
WResize ,
EwResize ,
NsResize ,
NeswResize ,
NwseResize ,
ColResize ,
RowResize ,
}
2017-10-17 14:56:38 +03:00
2019-05-29 21:29:54 -04:00
impl Default for CursorIcon {
2019-02-05 10:30:33 -05:00
fn default ( ) -> Self {
2019-05-29 21:29:54 -04:00
CursorIcon ::Default
2017-10-17 14:56:38 +03:00
}
2015-02-16 09:29:37 +01:00
}
2019-07-29 21:16:14 +03:00
2020-09-22 04:54:47 +03:00
/// Fullscreen modes.
2019-07-29 21:16:14 +03:00
#[ derive(Clone, Debug, PartialEq) ]
pub enum Fullscreen {
Exclusive ( VideoMode ) ,
2020-09-22 04:54:47 +03:00
/// Providing `None` to `Borderless` will fullscreen on the current monitor.
Borderless ( Option < MonitorHandle > ) ,
2019-07-29 21:16:14 +03:00
}
2019-12-22 19:04:09 +00:00
2020-11-30 19:04:26 +01:00
#[ derive(Clone, Copy, Debug, PartialEq) ]
2019-12-22 19:04:09 +00:00
pub enum Theme {
Light ,
Dark ,
}
2020-11-27 03:03:08 +01:00
/// ## Platform-specific
///
/// - **X11:** Sets the WM's `XUrgencyHint`. No distinction between `Critical` and `Informational`.
#[ derive(Debug, Clone, Copy, PartialEq) ]
pub enum UserAttentionType {
/// ## Platform-specific
/// - **macOS:** Bounces the dock icon until the application is in focus.
/// - **Windows:** Flashes both the window and the taskbar button until the application is in focus.
Critical ,
/// ## Platform-specific
/// - **macOS:** Bounces the dock icon once.
/// - **Windows:** Flashes the taskbar button until the application is in focus.
Informational ,
}
impl Default for UserAttentionType {
fn default ( ) -> Self {
UserAttentionType ::Informational
}
}