From 5331397c6cf72752afe3bb56d9f74ab99e127f8b Mon Sep 17 00:00:00 2001 From: Lucas Kent Date: Sun, 2 Jan 2022 14:56:13 +1100 Subject: [PATCH] Provide examples for all window position/size setters (#2107) --- src/platform/unix.rs | 22 +++++++++++++ src/window.rs | 78 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 100 insertions(+) diff --git a/src/platform/unix.rs b/src/platform/unix.rs index 79f65f9d..ba600b13 100644 --- a/src/platform/unix.rs +++ b/src/platform/unix.rs @@ -345,9 +345,31 @@ pub trait WindowBuilderExtUnix { #[cfg(feature = "x11")] fn with_gtk_theme_variant(self, variant: String) -> Self; /// Build window with resize increment hint. Only implemented on X11. + /// + /// ``` + /// # use winit::dpi::{LogicalSize, PhysicalSize}; + /// # use winit::window::WindowBuilder; + /// # use winit::platform::unix::WindowBuilderExtUnix; + /// // Specify the size in logical dimensions like this: + /// WindowBuilder::new().with_resize_increments(LogicalSize::new(400.0, 200.0)); + /// + /// // Or specify the size in physical dimensions like this: + /// WindowBuilder::new().with_resize_increments(PhysicalSize::new(400, 200)); + /// ``` #[cfg(feature = "x11")] fn with_resize_increments>(self, increments: S) -> Self; /// Build window with base size hint. Only implemented on X11. + /// + /// ``` + /// # use winit::dpi::{LogicalSize, PhysicalSize}; + /// # use winit::window::WindowBuilder; + /// # use winit::platform::unix::WindowBuilderExtUnix; + /// // Specify the size in logical dimensions like this: + /// WindowBuilder::new().with_base_size(LogicalSize::new(400.0, 200.0)); + /// + /// // Or specify the size in physical dimensions like this: + /// WindowBuilder::new().with_base_size(PhysicalSize::new(400, 200)); + /// ``` #[cfg(feature = "x11")] fn with_base_size>(self, base_size: S) -> Self; diff --git a/src/window.rs b/src/window.rs index 59c8c59f..3e7100bc 100644 --- a/src/window.rs +++ b/src/window.rs @@ -496,6 +496,19 @@ impl Window { /// See `outer_position` for more information about the coordinates. This automatically un-maximizes the /// window if it's maximized. /// + /// ```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)); + /// ``` + /// /// ## Platform-specific /// /// - **iOS:** Can only be called on the main thread. Sets the top left coordinates of the @@ -528,6 +541,19 @@ impl Window { /// See `inner_size` for more information about the values. This automatically un-maximizes the /// window if it's maximized. /// + /// ```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)); + /// ``` + /// /// ## Platform-specific /// /// - **iOS / Android:** Unsupported. @@ -555,6 +581,19 @@ impl Window { /// Sets a minimum dimension size for the window. /// + /// ```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))); + /// ``` + /// /// ## Platform-specific /// /// - **iOS / Android / Web:** Unsupported. @@ -565,6 +604,19 @@ impl Window { /// Sets a maximum dimension size for the window. /// + /// ```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))); + /// ``` + /// /// ## Platform-specific /// /// - **iOS / Android / Web:** Unsupported. @@ -727,6 +779,19 @@ impl Window { /// Sets location of IME candidate box in client area coordinates relative to the top left. /// + /// ```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)); + /// ``` + /// /// ## Platform-specific /// /// - **iOS / Android / Web:** Unsupported. @@ -783,6 +848,19 @@ impl Window { /// Changes the position of the cursor in window coordinates. /// + /// ```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)); + /// ``` + /// /// ## Platform-specific /// /// - **iOS / Android / Web / Wayland:** Always returns an [`ExternalError::NotSupported`].