Struct Window

Source
pub struct Window<Data: 'static> { /* private fields */ }
Expand description

The window widget

This widget is the root of any UI tree used as a window. It manages window decorations.

To change window properties at run-time, send a WindowCommand from a child widget.

Implementations§

Source§

impl<Data: 'static> Window<Data>

Source

pub fn new(ui: impl Widget<Data = Data> + 'static, title: impl ToString) -> Self

Construct a window with a W: Widget and a title

Source

pub fn new_boxed(ui: Box<dyn Widget<Data = Data>>, title: impl ToString) -> Self

Construct a window from a boxed ui widget and a title

Source

pub fn title(&self) -> &str

Get the window’s title

Source

pub fn with_icon(self, icon: impl Into<Option<Icon>>) -> Self

Set the window’s icon (inline)

Default: None

Source

pub fn decorations(&self) -> Decorations

Get the preference for window decorations

Source

pub fn with_decorations(self, decorations: Decorations) -> Self

Set the preference for window decorations

“Windowing” platforms (i.e. not mobile or web) usually include a title-bar, icons and potentially side borders. These are known as decorations.

This controls the preferred type of decorations. The resulting behaviour is platform-dependent.

Default: Decorations::Server.

Source

pub fn restrictions(&self) -> (bool, bool)

Get window resizing restrictions: (restrict_min, restrict_max)

Source

pub fn with_restrictions(self, restrict_min: bool, restrict_max: bool) -> Self

Whether to limit the maximum size of a window

All widgets’ size rules allow calculation of two sizes: the minimum size and the ideal size. Windows are initially sized to the ideal size.

If restrict_min, the window may not be sized below the minimum size. Default value: true.

If restrict_max, the window may not be sized above the ideal size. Default value: false.

Source

pub fn drag_anywhere(&self) -> bool

Get “drag anywhere” state

Source

pub fn with_drag_anywhere(self, drag_anywhere: bool) -> Self

Whether to allow dragging the window from the background

If true, then any unhandled click+drag in the window may be used to drag the window on supported platforms. Default value: true.

Source

pub fn transparent(&self) -> bool

Get whether this window should use transparent rendering

Source

pub fn with_transparent(self, transparent: bool) -> Self

Whether the window supports transparency

If true, painting with alpha < 1.0 makes the background visible. Additionally, window draw targets are cleared to transparent. This does not stop theme elements from drawing a solid background.

Note: results may vary by platform. Current output does not use pre-multiplied alpha which some platforms expect, thus pixels with partial transparency may have incorrect appearance.

Default: false.

Trait Implementations§

Source§

impl<Data: 'static> Debug for Window<Data>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<Data: 'static> Events for Window<Data>

Source§

fn configure(&mut self, cx: &mut ConfigCx<'_>)

Configure self Read more
Source§

fn handle_event( &mut self, cx: &mut EventCx<'_>, _: &Self::Data, event: Event, ) -> IsUsed

Handle an Event Read more
Source§

fn handle_messages(&mut self, cx: &mut EventCx<'_>, _: &Self::Data)

Handler for messages from children/descendants Read more
Source§

fn handle_scroll(&mut self, cx: &mut EventCx<'_>, data: &Data, _: Scroll)

Handler for scrolling Read more
Source§

fn make_child_id(&mut self, index: usize) -> Id

Make an identifier for a child Read more
Source§

fn configure_recurse(&mut self, cx: &mut ConfigCx<'_>, data: &Self::Data)

Configure children Read more
Source§

fn update(&mut self, cx: &mut ConfigCx<'_>, data: &Self::Data)

Update self using input data Read more
Source§

fn update_recurse(&mut self, cx: &mut ConfigCx<'_>, data: &Self::Data)

Update children Read more
Source§

fn navigable(&self) -> bool

Is this widget navigable via Tab key? Read more
Source§

fn handle_hover(&mut self, cx: &mut EventCx<'_>, state: bool)

Mouse focus handler Read more
Source§

impl<Data: 'static> Layout for Window<Data>

Source§

fn size_rules(&mut self, sizer: SizeCx<'_>, axis: AxisInfo) -> SizeRules

Get size rules for the given axis Read more
Source§

fn set_rect(&mut self, cx: &mut ConfigCx<'_>, rect: Rect, hints: AlignHints)

Set size and position Read more
Source§

fn find_id(&mut self, _: Coord) -> Option<Id>

Translate a coordinate to an Id Read more
Source§

fn draw(&mut self, _: DrawCx<'_>)

Draw a widget and its children Read more
Source§

fn as_layout(&self) -> &dyn Layout

Get as a dyn Layout Read more
Source§

fn id_ref(&self) -> &Id

Get the widget’s identifier Read more
Source§

fn rect(&self) -> Rect

Get the widget’s region, relative to its parent. Read more
Source§

fn widget_name(&self) -> &'static str

Get the name of the widget struct Read more
Source§

fn num_children(&self) -> usize

Get the number of child widgets Read more
Source§

fn get_child(&self, index: usize) -> Option<&dyn Layout>

Access a child as a dyn Layout Read more
Source§

fn nav_next(&self, reverse: bool, from: Option<usize>) -> Option<usize>

Navigation in spatial order Read more
Source§

fn find_child_index(&self, id: &Id) -> Option<usize>

Find the child which is an ancestor of this id, if any Read more
Source§

fn translation(&self) -> Offset

Get translation of children relative to this widget Read more
Source§

impl<Data: 'static> Widget for Window<Data>

Source§

type Data = Data

Input data type Read more
Source§

fn as_node<'a>(&'a mut self, data: &'a Self::Data) -> Node<'a>

Erase type Read more
Source§

fn for_child_node( &mut self, data: &Self::Data, index: usize, closure: Box<dyn FnOnce(Node<'_>) + '_>, )

Call closure on child with given index, if index < self.num_children(). Read more

Auto Trait Implementations§

§

impl<Data> Freeze for Window<Data>

§

impl<Data> !RefUnwindSafe for Window<Data>

§

impl<Data> !Send for Window<Data>

§

impl<Data> !Sync for Window<Data>

§

impl<Data> Unpin for Window<Data>

§

impl<Data> !UnwindSafe for Window<Data>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<S, T> Cast<T> for S
where T: Conv<S>,

Source§

fn cast(self) -> T

Cast from Self to T Read more
Source§

fn try_cast(self) -> Result<T, Error>

Try converting from Self to T Read more
Source§

impl<S, T> CastApprox<T> for S
where T: ConvApprox<S>,

Source§

fn try_cast_approx(self) -> Result<T, Error>

Try approximate conversion from Self to T Read more
Source§

fn cast_approx(self) -> T

Cast approximately from Self to T Read more
Source§

impl<S, T> CastFloat<T> for S
where T: ConvFloat<S>,

Source§

fn cast_trunc(self) -> T

Cast to integer, truncating Read more
Source§

fn cast_nearest(self) -> T

Cast to the nearest integer Read more
Source§

fn cast_floor(self) -> T

Cast the floor to an integer Read more
Source§

fn cast_ceil(self) -> T

Cast the ceiling to an integer Read more
Source§

fn try_cast_trunc(self) -> Result<T, Error>

Try converting to integer with truncation Read more
Source§

fn try_cast_nearest(self) -> Result<T, Error>

Try converting to the nearest integer Read more
Source§

fn try_cast_floor(self) -> Result<T, Error>

Try converting the floor to an integer Read more
Source§

fn try_cast_ceil(self) -> Result<T, Error>

Try convert the ceiling to an integer Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<W> LayoutExt for W
where W: Layout + ?Sized,

Source§

fn id(&self) -> Id

Get the widget’s identifier Read more
Source§

fn eq_id<T>(&self, rhs: T) -> bool
where Id: PartialEq<T>,

Test widget identifier for equality Read more
Source§

fn identify(&self) -> IdentifyWidget<'_>

Display as “StructName#Id”
Source§

fn is_ancestor_of(&self, id: &Id) -> bool

Check whether id is self or a descendant Read more
Source§

fn is_strict_ancestor_of(&self, id: &Id) -> bool

Check whether id is not self and is a descendant Read more
Source§

fn for_children(&self, f: impl FnMut(&dyn Layout))

Run a closure on all children
Source§

fn for_children_try<E>( &self, f: impl FnMut(&dyn Layout) -> Result<(), E>, ) -> Result<(), E>

Run a fallible closure on all children Read more
Source§

fn find_widget(&self, id: &Id) -> Option<&dyn Layout>

Find the descendant with this id, if any Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more