diff options
author | 2024-09-05 11:13:37 +0200 | |
---|---|---|
committer | 2024-09-05 11:13:37 +0200 | |
commit | 64ec099a9b4490a424d35a4be37c564177e71edf (patch) | |
tree | cd6c94ddb09fb0c768651d8bb47cfcb1f8959616 /runtime | |
parent | 6009420b57933ccf799f1b7eac8debab950cdd5e (diff) | |
download | iced-64ec099a9b4490a424d35a4be37c564177e71edf.tar.gz iced-64ec099a9b4490a424d35a4be37c564177e71edf.tar.bz2 iced-64ec099a9b4490a424d35a4be37c564177e71edf.zip |
Add mouse passthrough tasks to `window` module
Co-authored-by: Jose Quesada <jquesada2016@fau.edu>
Diffstat (limited to 'runtime')
-rw-r--r-- | runtime/src/window.rs | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/runtime/src/window.rs b/runtime/src/window.rs index ce6fd1b6..cdf3d80a 100644 --- a/runtime/src/window.rs +++ b/runtime/src/window.rs @@ -147,6 +147,18 @@ pub enum Action { /// Screenshot the viewport of the window. Screenshot(Id, oneshot::Sender<Screenshot>), + + /// Enables mouse passthrough for the given window. + /// + /// This disables mouse events for the window and passes mouse events + /// through to whatever window is underneath. + EnableMousePassthrough(Id), + + /// Disable mouse passthrough for the given window. + /// + /// This enables mouse events for the window and stops mouse events + /// from being passed to whatever is underneath. + DisableMousePassthrough(Id), } /// Subscribes to the frames of the window of the running application. @@ -406,3 +418,19 @@ pub fn screenshot(id: Id) -> Task<Screenshot> { crate::Action::Window(Action::Screenshot(id, channel)) }) } + +/// Enables mouse passthrough for the given window. +/// +/// This disables mouse events for the window and passes mouse events +/// through to whatever window is underneath. +pub fn enable_mouse_passthrough<Message>(id: Id) -> Task<Message> { + task::effect(crate::Action::Window(Action::EnableMousePassthrough(id))) +} + +/// Disable mouse passthrough for the given window. +/// +/// This enables mouse events for the window and stops mouse events +/// from being passed to whatever is underneath. +pub fn disable_mouse_passthrough<Message>(id: Id) -> Task<Message> { + task::effect(crate::Action::Window(Action::DisableMousePassthrough(id))) +} |