Struct i_slint_core::window::WindowInner

source ·
pub struct WindowInner {
    pub focus_item: RefCell<ItemWeak>,
    /* private fields */
}
Expand description

Inner datastructure for the crate::api::Window

Fields§

§focus_item: RefCell<ItemWeak>

ItemRC that currently have the focus. (possibly a, instance of TextInput)

Implementations§

source§

impl WindowInner

source

pub fn new(window_adapter_weak: Weak<dyn WindowAdapter>) -> Self

Create a new instance of the window, given the window_adapter factory fn

source

pub fn set_component(&self, component: &ItemTreeRc)

Associates this window with the specified component. Further event handling and rendering, etc. will be done with that component.

source

pub fn component(&self) -> ItemTreeRc

return the component. Panics if it wasn’t set.

source

pub fn try_component(&self) -> Option<ItemTreeRc>

returns the component or None if it isn’t set.

source

pub fn process_mouse_input(&self, event: MouseEvent)

Receive a mouse event and pass it to the items of the component to change their state.

Arguments:

  • pos: The position of the mouse event in window physical coordinates.
  • what: The type of mouse event.
  • component: The Slint compiled component that provides the tree of items.
source

pub fn process_key_input(&self, event: KeyEvent)

Receive a key event and pass it to the items of the component to change their state.

Arguments:

  • event: The key event received by the windowing system.
  • component: The Slint compiled component that provides the tree of items.

Installs a binding on the specified property that’s toggled whenever the text cursor is supposed to be visible or not.

source

pub fn set_focus_item(&self, new_focus_item: &ItemRc, set_focus: bool)

Sets the focus to the item pointed to by item_ptr. This will remove the focus from any currently focused item. If set_focus is false, the focus is cleared.

source

pub fn focus_next_item(&self)

Move keyboard focus to the next item

source

pub fn focus_previous_item(&self)

Move keyboard focus to the previous item.

source

pub fn set_active(&self, have_focus: bool)

Marks the window to be the active window. This typically coincides with the keyboard focus. One exception though is when a popup is shown, in which case the window may remain active but temporarily loose focus to the popup.

This results in WindowFocusReceived and WindowFocusLost events.

source

pub fn active(&self) -> bool

Returns true of the window is the active window. That typically implies having the keyboard focus, except when a popup is shown and temporarily takes the focus.

source

pub fn update_window_properties(&self)

If the component’s root item is a Window element, then this function synchronizes its properties, such as the title for example, with the properties known to the windowing system.

source

pub fn draw_contents<T>( &self, render_components: impl FnOnce(&[(&ItemTreeRc, LogicalPoint)]) -> T, ) -> Option<T>

Calls the render_components to render the main component and any sub-window components, tracked by a property dependency tracker. Returns None if no component is set yet.

source

pub fn show(&self) -> Result<(), PlatformError>

Registers the window with the windowing system, in order to render the component’s items and react to input events once the event loop spins.

source

pub fn hide(&self) -> Result<(), PlatformError>

De-registers the window with the windowing system.

source

pub fn color_scheme(&self) -> ColorScheme

returns the color theme used

source

pub fn show_popup( &self, popup_componentrc: &ItemTreeRc, position: Point, close_on_click: bool, parent_item: &ItemRc, )

Show a popup at the given position relative to the item

source

pub fn close_popup(&self)

Removes any active popup. TODO: this function should take a component ref as parameter, to close a specific popup - i.e. when popup menus create a hierarchy of popups.

source

pub fn close_popup_on_click(&self) -> bool

Returns true if the currently active popup is configured to close on click. None if there is no active popup.

source

pub fn scale_factor(&self) -> f32

Returns the scale factor set on the window, as provided by the windowing system.

source

pub fn text_input_focused(&self) -> bool

Reads the global property TextInputInterface.text-input-focused

source

pub fn set_text_input_focused(&self, value: bool)

Sets the global property TextInputInterface.text-input-focused

source

pub fn is_visible(&self) -> bool

Returns true if the window is visible

source

pub fn window_item(&self) -> Option<VRcMapped<ItemTreeVTable, WindowItem>>

Returns the window item that is the first item in the component.

source

pub fn on_close_requested( &self, callback: impl FnMut() -> CloseRequestResponse + 'static, )

Sets the close_requested callback. The callback will be run when the user tries to close a window.

source

pub fn request_close(&self) -> bool

Runs the close_requested callback. If the callback returns KeepWindowShown, this function returns false. That should prevent the Window from closing. Otherwise it returns true, which allows the Window to hide.

source

pub fn is_fullscreen(&self) -> bool

Returns if the window is currently maximized

source

pub fn set_fullscreen(&self, enabled: bool)

Set or unset the window to display fullscreen.

source

pub fn is_maximized(&self) -> bool

Returns if the window is currently maximized

source

pub fn set_maximized(&self, maximized: bool)

Set the window as maximized or unmaximized

source

pub fn is_minimized(&self) -> bool

Returns if the window is currently minimized

source

pub fn set_minimized(&self, minimized: bool)

Set the window as minimized or unminimized

source

pub fn window_adapter(&self) -> Rc<dyn WindowAdapter>

Returns the upgraded window adapter

source

pub fn from_pub(window: &Window) -> &Self

Private access to the WindowInner for a given window.

Trait Implementations§

source§

impl Drop for WindowInner

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

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<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

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, 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.