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
impl WindowInner
sourcepub fn new(window_adapter_weak: Weak<dyn WindowAdapter>) -> Self
pub fn new(window_adapter_weak: Weak<dyn WindowAdapter>) -> Self
Create a new instance of the window, given the window_adapter factory fn
sourcepub fn set_component(&self, component: &ItemTreeRc)
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.
sourcepub fn component(&self) -> ItemTreeRc
pub fn component(&self) -> ItemTreeRc
return the component. Panics if it wasn’t set.
sourcepub fn try_component(&self) -> Option<ItemTreeRc>
pub fn try_component(&self) -> Option<ItemTreeRc>
returns the component or None if it isn’t set.
sourcepub fn process_mouse_input(&self, event: MouseEvent)
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.
sourcepub fn process_key_input(&self, event: KeyEvent)
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.
sourcepub fn set_cursor_blink_binding(&self, prop: &Property<bool>)
pub fn set_cursor_blink_binding(&self, prop: &Property<bool>)
Installs a binding on the specified property that’s toggled whenever the text cursor is supposed to be visible or not.
sourcepub fn set_focus_item(&self, new_focus_item: &ItemRc, set_focus: bool)
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.
sourcepub fn focus_next_item(&self)
pub fn focus_next_item(&self)
Move keyboard focus to the next item
sourcepub fn focus_previous_item(&self)
pub fn focus_previous_item(&self)
Move keyboard focus to the previous item.
sourcepub fn set_active(&self, have_focus: bool)
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.
sourcepub fn active(&self) -> bool
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.
sourcepub fn update_window_properties(&self)
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.
sourcepub fn draw_contents<T>(
&self,
render_components: impl FnOnce(&[(&ItemTreeRc, LogicalPoint)]) -> T,
) -> Option<T>
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.
sourcepub fn show(&self) -> Result<(), PlatformError>
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.
sourcepub fn hide(&self) -> Result<(), PlatformError>
pub fn hide(&self) -> Result<(), PlatformError>
De-registers the window with the windowing system.
sourcepub fn color_scheme(&self) -> ColorScheme
pub fn color_scheme(&self) -> ColorScheme
returns the color theme used
sourcepub fn show_popup(
&self,
popup_componentrc: &ItemTreeRc,
position: Point,
close_on_click: bool,
parent_item: &ItemRc,
)
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
sourcepub fn close_popup(&self)
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.
sourcepub fn close_popup_on_click(&self) -> bool
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.
sourcepub fn scale_factor(&self) -> f32
pub fn scale_factor(&self) -> f32
Returns the scale factor set on the window, as provided by the windowing system.
sourcepub fn text_input_focused(&self) -> bool
pub fn text_input_focused(&self) -> bool
Reads the global property TextInputInterface.text-input-focused
sourcepub fn set_text_input_focused(&self, value: bool)
pub fn set_text_input_focused(&self, value: bool)
Sets the global property TextInputInterface.text-input-focused
sourcepub fn is_visible(&self) -> bool
pub fn is_visible(&self) -> bool
Returns true if the window is visible
sourcepub fn window_item(&self) -> Option<VRcMapped<ItemTreeVTable, WindowItem>>
pub fn window_item(&self) -> Option<VRcMapped<ItemTreeVTable, WindowItem>>
Returns the window item that is the first item in the component.
sourcepub fn on_close_requested(
&self,
callback: impl FnMut() -> CloseRequestResponse + 'static,
)
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.
sourcepub fn request_close(&self) -> bool
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.
sourcepub fn is_fullscreen(&self) -> bool
pub fn is_fullscreen(&self) -> bool
Returns if the window is currently maximized
sourcepub fn set_fullscreen(&self, enabled: bool)
pub fn set_fullscreen(&self, enabled: bool)
Set or unset the window to display fullscreen.
sourcepub fn is_maximized(&self) -> bool
pub fn is_maximized(&self) -> bool
Returns if the window is currently maximized
sourcepub fn set_maximized(&self, maximized: bool)
pub fn set_maximized(&self, maximized: bool)
Set the window as maximized or unmaximized
sourcepub fn is_minimized(&self) -> bool
pub fn is_minimized(&self) -> bool
Returns if the window is currently minimized
sourcepub fn set_minimized(&self, minimized: bool)
pub fn set_minimized(&self, minimized: bool)
Set the window as minimized or unminimized
sourcepub fn window_adapter(&self) -> Rc<dyn WindowAdapter>
pub fn window_adapter(&self) -> Rc<dyn WindowAdapter>
Returns the upgraded window adapter