summaryrefslogtreecommitdiffstats
path: root/native/src/widget/slider.rs
diff options
context:
space:
mode:
authorLibravatar Sebastian Imlay <sebastian.imlay@gmail.com>2019-11-11 20:29:58 -0800
committerLibravatar Sebastian Imlay <sebastian.imlay@gmail.com>2020-03-18 11:26:53 -0700
commite19a07d40049f40f36d879a498fab4ce63778b27 (patch)
tree6ecdcb5345f6c00c2b53ee4d93afd8585c1dda2e /native/src/widget/slider.rs
parent9da6ce474c2cd178ca5365d46760ba0882ce7121 (diff)
downloadiced-e19a07d40049f40f36d879a498fab4ce63778b27.tar.gz
iced-e19a07d40049f40f36d879a498fab4ce63778b27.tar.bz2
iced-e19a07d40049f40f36d879a498fab4ce63778b27.zip
Added initial touch events to support iOS
Diffstat (limited to 'native/src/widget/slider.rs')
-rw-r--r--native/src/widget/slider.rs30
1 files changed, 17 insertions, 13 deletions
diff --git a/native/src/widget/slider.rs b/native/src/widget/slider.rs
index 008203fe..95f63921 100644
--- a/native/src/widget/slider.rs
+++ b/native/src/widget/slider.rs
@@ -5,7 +5,7 @@
//! [`Slider`]: struct.Slider.html
//! [`State`]: struct.State.html
use crate::{
- input::{mouse, ButtonState},
+ input::{mouse, touch::Touch, ButtonState},
layout, Clipboard, Element, Event, Hasher, Layout, Length, Point,
Rectangle, Size, Widget,
};
@@ -166,19 +166,23 @@ where
match event {
Event::Mouse(mouse::Event::Input {
button: mouse::Button::Left,
- state,
- }) => match state {
- ButtonState::Pressed => {
- if layout.bounds().contains(cursor_position) {
- change();
- self.state.is_dragging = true;
- }
- }
- ButtonState::Released => {
- self.state.is_dragging = false;
+ state: ButtonState::Pressed,
+ })
+ | Event::Touch(Touch::Started { .. }) => {
+ if layout.bounds().contains(cursor_position) {
+ change();
+ self.state.is_dragging = true;
}
- },
- Event::Mouse(mouse::Event::CursorMoved { .. }) => {
+ }
+ Event::Mouse(mouse::Event::Input {
+ button: mouse::Button::Left,
+ state: ButtonState::Released,
+ })
+ | Event::Touch(Touch::Ended { .. }) => {
+ self.state.is_dragging = false;
+ }
+ Event::Mouse(mouse::Event::CursorMoved { .. })
+ | Event::Touch(Touch::Moved { .. }) => {
if self.state.is_dragging {
change();
}