summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2020-01-16 18:34:29 +0100
committerLibravatar GitHub <noreply@github.com>2020-01-16 18:34:29 +0100
commit6ca5e6184f9f1c12b427bdafcce0b4e9fbc5bb14 (patch)
tree8ff337ba8503eb1af3f2211c5f969c2db87c96fd
parent11495b48eec8cdb6e4e3ae450983b26fe6b2eb15 (diff)
parentb3106738eba09a7dec98f28738ab29996654491f (diff)
downloadiced-6ca5e6184f9f1c12b427bdafcce0b4e9fbc5bb14.tar.gz
iced-6ca5e6184f9f1c12b427bdafcce0b4e9fbc5bb14.tar.bz2
iced-6ca5e6184f9f1c12b427bdafcce0b4e9fbc5bb14.zip
Merge pull request #162 from hecrj/feature/window-file-events
Window file events
-rw-r--r--native/src/event.rs2
-rw-r--r--native/src/widget/column.rs2
-rw-r--r--native/src/widget/row.rs2
-rw-r--r--native/src/window/event.rs22
-rw-r--r--winit/src/application.rs38
-rw-r--r--winit/src/subscription.rs2
6 files changed, 50 insertions, 18 deletions
diff --git a/native/src/event.rs b/native/src/event.rs
index 1d28aa7b..b2550ead 100644
--- a/native/src/event.rs
+++ b/native/src/event.rs
@@ -9,7 +9,7 @@ use crate::{
/// additional events, feel free to [open an issue] and share your use case!_
///
/// [open an issue]: https://github.com/hecrj/iced/issues
-#[derive(PartialEq, Clone, Copy, Debug)]
+#[derive(PartialEq, Clone, Debug)]
pub enum Event {
/// A keyboard event
Keyboard(keyboard::Event),
diff --git a/native/src/widget/column.rs b/native/src/widget/column.rs
index 79ec5ab4..104790d4 100644
--- a/native/src/widget/column.rs
+++ b/native/src/widget/column.rs
@@ -159,7 +159,7 @@ where
self.children.iter_mut().zip(layout.children()).for_each(
|(child, layout)| {
child.widget.on_event(
- event,
+ event.clone(),
layout,
cursor_position,
messages,
diff --git a/native/src/widget/row.rs b/native/src/widget/row.rs
index b3dc90ba..775b953e 100644
--- a/native/src/widget/row.rs
+++ b/native/src/widget/row.rs
@@ -160,7 +160,7 @@ where
self.children.iter_mut().zip(layout.children()).for_each(
|(child, layout)| {
child.widget.on_event(
- event,
+ event.clone(),
layout,
cursor_position,
messages,
diff --git a/native/src/window/event.rs b/native/src/window/event.rs
index 89ec0a0c..b177141a 100644
--- a/native/src/window/event.rs
+++ b/native/src/window/event.rs
@@ -1,5 +1,7 @@
+use std::path::PathBuf;
+
/// A window-related event.
-#[derive(PartialEq, Clone, Copy, Debug)]
+#[derive(PartialEq, Clone, Debug)]
pub enum Event {
/// A window was resized
Resized {
@@ -9,4 +11,22 @@ pub enum Event {
/// The new height of the window (in units)
height: u32,
},
+
+ /// A file is being hovered over the window.
+ ///
+ /// When the user hovers multiple files at once, this event will be emitted
+ /// for each file separately.
+ FileHovered(PathBuf),
+
+ /// A file has beend dropped into the window.
+ ///
+ /// When the user drops multiple files at once, this event will be emitted
+ /// for each file separately.
+ FileDropped(PathBuf),
+
+ /// A file was hovered, but has exited the window.
+ ///
+ /// There will be a single `FilesHoveredLeft` event triggered even if
+ /// multiple files were hovered.
+ FilesHoveredLeft,
}
diff --git a/winit/src/application.rs b/winit/src/application.rs
index 9e8eaebb..a14924ac 100644
--- a/winit/src/application.rs
+++ b/winit/src/application.rs
@@ -209,9 +209,10 @@ pub trait Application: Sized {
);
debug.event_processing_started();
- events.iter().for_each(|event| {
- subscription_pool.broadcast_event(*event)
- });
+ events
+ .iter()
+ .cloned()
+ .for_each(|event| subscription_pool.broadcast_event(event));
let mut messages = user_interface.update(
&renderer,
@@ -330,6 +331,18 @@ pub trait Application: Sized {
event: window_event,
..
} => match window_event {
+ WindowEvent::Resized(new_size) => {
+ events.push(Event::Window(window::Event::Resized {
+ width: new_size.width.round() as u32,
+ height: new_size.height.round() as u32,
+ }));
+
+ size = new_size;
+ resized = true;
+ }
+ WindowEvent::CloseRequested => {
+ *control_flow = ControlFlow::Exit;
+ }
WindowEvent::CursorMoved { position, .. } => {
events.push(Event::Mouse(mouse::Event::CursorMoved {
x: position.x as f32,
@@ -398,17 +411,16 @@ pub trait Application: Sized {
modifiers: conversion::modifiers_state(modifiers),
}));
}
- WindowEvent::CloseRequested => {
- *control_flow = ControlFlow::Exit;
+ WindowEvent::HoveredFile(path) => {
+ events
+ .push(Event::Window(window::Event::FileHovered(path)));
}
- WindowEvent::Resized(new_size) => {
- events.push(Event::Window(window::Event::Resized {
- width: new_size.width.round() as u32,
- height: new_size.height.round() as u32,
- }));
-
- size = new_size;
- resized = true;
+ WindowEvent::DroppedFile(path) => {
+ events
+ .push(Event::Window(window::Event::FileDropped(path)));
+ }
+ WindowEvent::HoveredFileCancelled => {
+ events.push(Event::Window(window::Event::FilesHoveredLeft));
}
_ => {}
},
diff --git a/winit/src/subscription.rs b/winit/src/subscription.rs
index f55507af..bad68d55 100644
--- a/winit/src/subscription.rs
+++ b/winit/src/subscription.rs
@@ -86,7 +86,7 @@ impl Pool {
.values_mut()
.filter_map(|connection| connection.listener.as_mut())
.for_each(|listener| {
- if let Err(error) = listener.try_send(event) {
+ if let Err(error) = listener.try_send(event.clone()) {
log::error!(
"Error sending event to subscription: {:?}",
error