summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
Diffstat (limited to 'core')
-rw-r--r--core/src/button_state.rs9
-rw-r--r--core/src/lib.rs5
-rw-r--r--core/src/mouse.rs6
-rw-r--r--core/src/mouse/button.rs15
-rw-r--r--core/src/mouse/event.rs61
-rw-r--r--core/src/mouse_cursor.rs36
-rw-r--r--core/src/point.rs10
-rw-r--r--core/src/rectangle.rs58
8 files changed, 196 insertions, 4 deletions
diff --git a/core/src/button_state.rs b/core/src/button_state.rs
new file mode 100644
index 00000000..988043ba
--- /dev/null
+++ b/core/src/button_state.rs
@@ -0,0 +1,9 @@
+/// The state of a button.
+#[derive(Debug, Hash, Ord, PartialOrd, PartialEq, Eq, Clone, Copy)]
+pub enum ButtonState {
+ /// The button is pressed.
+ Pressed,
+
+ /// The button is __not__ pressed.
+ Released,
+}
diff --git a/core/src/lib.rs b/core/src/lib.rs
index c2887a0b..f0072f61 100644
--- a/core/src/lib.rs
+++ b/core/src/lib.rs
@@ -15,12 +15,15 @@
#![forbid(unsafe_code)]
#![forbid(rust_2018_idioms)]
pub mod keyboard;
+pub mod mouse;
mod align;
mod background;
+mod button_state;
mod color;
mod font;
mod length;
+mod mouse_cursor;
mod point;
mod rectangle;
mod size;
@@ -28,9 +31,11 @@ mod vector;
pub use align::{Align, HorizontalAlignment, VerticalAlignment};
pub use background::Background;
+pub use button_state::ButtonState;
pub use color::Color;
pub use font::Font;
pub use length::Length;
+pub use mouse_cursor::MouseCursor;
pub use point::Point;
pub use rectangle::Rectangle;
pub use size::Size;
diff --git a/core/src/mouse.rs b/core/src/mouse.rs
new file mode 100644
index 00000000..101e04d5
--- /dev/null
+++ b/core/src/mouse.rs
@@ -0,0 +1,6 @@
+//! Reuse basic mouse types.
+mod button;
+mod event;
+
+pub use button::Button;
+pub use event::{Event, ScrollDelta};
diff --git a/core/src/mouse/button.rs b/core/src/mouse/button.rs
new file mode 100644
index 00000000..aeb8a55d
--- /dev/null
+++ b/core/src/mouse/button.rs
@@ -0,0 +1,15 @@
+/// The button of a mouse.
+#[derive(Debug, Hash, PartialEq, Eq, Clone, Copy)]
+pub enum Button {
+ /// The left mouse button.
+ Left,
+
+ /// The right mouse button.
+ Right,
+
+ /// The middle (wheel) button.
+ Middle,
+
+ /// Some other button.
+ Other(u8),
+}
diff --git a/core/src/mouse/event.rs b/core/src/mouse/event.rs
new file mode 100644
index 00000000..52e9d851
--- /dev/null
+++ b/core/src/mouse/event.rs
@@ -0,0 +1,61 @@
+use super::Button;
+use crate::ButtonState;
+
+/// A mouse event.
+///
+/// _**Note:** This type is largely incomplete! If you need to track
+/// additional events, feel free to [open an issue] and share your use case!_
+///
+/// [open an issue]: https://github.com/hecrj/iced/issues
+#[derive(Debug, Clone, Copy, PartialEq)]
+pub enum Event {
+ /// The mouse cursor entered the window.
+ CursorEntered,
+
+ /// The mouse cursor left the window.
+ CursorLeft,
+
+ /// The mouse cursor was moved
+ CursorMoved {
+ /// The X coordinate of the mouse position
+ x: f32,
+
+ /// The Y coordinate of the mouse position
+ y: f32,
+ },
+
+ /// A mouse button was pressed or released.
+ Input {
+ /// The button identifier
+ button: Button,
+
+ /// The state of the button
+ state: ButtonState,
+ },
+
+ /// The mouse wheel was scrolled.
+ WheelScrolled {
+ /// The scroll movement.
+ delta: ScrollDelta,
+ },
+}
+
+/// A scroll movement.
+#[derive(Debug, Clone, Copy, PartialEq)]
+pub enum ScrollDelta {
+ /// A line-based scroll movement
+ Lines {
+ /// The number of horizontal lines scrolled
+ x: f32,
+
+ /// The number of vertical lines scrolled
+ y: f32,
+ },
+ /// A pixel-based scroll movement
+ Pixels {
+ /// The number of horizontal pixels scrolled
+ x: f32,
+ /// The number of vertical pixels scrolled
+ y: f32,
+ },
+}
diff --git a/core/src/mouse_cursor.rs b/core/src/mouse_cursor.rs
new file mode 100644
index 00000000..78ddb0ae
--- /dev/null
+++ b/core/src/mouse_cursor.rs
@@ -0,0 +1,36 @@
+/// The state of the mouse cursor.
+#[derive(Debug, Eq, PartialEq, Clone, Copy, PartialOrd, Ord)]
+pub enum MouseCursor {
+ /// The cursor is over a non-interactive widget.
+ Idle,
+
+ /// The cursor is over a clickable widget.
+ Pointer,
+
+ /// The cursor is over a busy widget.
+ Working,
+
+ /// The cursor is over a grabbable widget.
+ Grab,
+
+ /// The cursor is over a text widget.
+ Text,
+
+ /// The cursor is over a widget that requires precision.
+ Crosshair,
+
+ /// The cursor is grabbing a widget.
+ Grabbing,
+
+ /// The cursor is resizing a widget horizontally.
+ ResizingHorizontally,
+
+ /// The cursor is resizing a widget vertically.
+ ResizingVertically,
+}
+
+impl Default for MouseCursor {
+ fn default() -> MouseCursor {
+ MouseCursor::Idle
+ }
+}
diff --git a/core/src/point.rs b/core/src/point.rs
index 2b5ad154..3714aa2f 100644
--- a/core/src/point.rs
+++ b/core/src/point.rs
@@ -1,7 +1,7 @@
use crate::Vector;
/// A 2D point.
-#[derive(Debug, Clone, Copy, PartialEq)]
+#[derive(Debug, Clone, Copy, PartialEq, Default)]
pub struct Point {
/// The X coordinate.
pub x: f32,
@@ -67,3 +67,11 @@ impl std::ops::Sub<Vector> for Point {
}
}
}
+
+impl std::ops::Sub<Point> for Point {
+ type Output = Vector;
+
+ fn sub(self, point: Point) -> Vector {
+ Vector::new(self.x - point.x, self.y - point.y)
+ }
+}
diff --git a/core/src/rectangle.rs b/core/src/rectangle.rs
index aead6e9a..6f953137 100644
--- a/core/src/rectangle.rs
+++ b/core/src/rectangle.rs
@@ -1,4 +1,4 @@
-use crate::Point;
+use crate::{Point, Size, Vector};
/// A rectangle.
#[derive(Debug, Clone, Copy, PartialEq, Eq, Default)]
@@ -17,6 +17,35 @@ pub struct Rectangle<T = f32> {
}
impl Rectangle<f32> {
+ /// Creates a new [`Rectangle`] with its top-left corner in the given
+ /// [`Point`] and with the provided [`Size`].
+ ///
+ /// [`Rectangle`]: struct.Rectangle.html
+ /// [`Point`]: struct.Point.html
+ /// [`Size`]: struct.Size.html
+ pub fn new(top_left: Point, size: Size) -> Self {
+ Self {
+ x: top_left.x,
+ y: top_left.y,
+ width: size.width,
+ height: size.height,
+ }
+ }
+
+ /// Creates a new [`Rectangle`] with its top-left corner at the origin
+ /// and with the provided [`Size`].
+ ///
+ /// [`Rectangle`]: struct.Rectangle.html
+ /// [`Size`]: struct.Size.html
+ pub fn with_size(size: Size) -> Self {
+ Self {
+ x: 0.0,
+ y: 0.0,
+ width: size.width,
+ height: size.height,
+ }
+ }
+
/// Returns the [`Point`] at the center of the [`Rectangle`].
///
/// [`Point`]: struct.Point.html
@@ -43,6 +72,14 @@ impl Rectangle<f32> {
self.y + self.height / 2.0
}
+ /// Returns the [`Size`] of the [`Rectangle`].
+ ///
+ /// [`Size`]: struct.Size.html
+ /// [`Rectangle`]: struct.Rectangle.html
+ pub fn size(&self) -> Size {
+ Size::new(self.width, self.height)
+ }
+
/// Returns true if the given [`Point`] is contained in the [`Rectangle`].
///
/// [`Point`]: struct.Point.html
@@ -112,8 +149,23 @@ impl From<Rectangle<f32>> for Rectangle<u32> {
Rectangle {
x: rectangle.x as u32,
y: rectangle.y as u32,
- width: rectangle.width.ceil() as u32,
- height: rectangle.height.ceil() as u32,
+ width: (rectangle.width + 0.5).round() as u32,
+ height: (rectangle.height + 0.5).round() as u32,
+ }
+ }
+}
+
+impl<T> std::ops::Add<Vector<T>> for Rectangle<T>
+where
+ T: std::ops::Add<Output = T>,
+{
+ type Output = Rectangle<T>;
+
+ fn add(self, translation: Vector<T>) -> Self {
+ Rectangle {
+ x: self.x + translation.x,
+ y: self.y + translation.y,
+ ..self
}
}
}