diff options
| author | 2024-04-23 10:45:44 +1000 | |
|---|---|---|
| committer | 2024-04-23 00:45:44 +0000 | |
| commit | fdcec0319757d2f87c82787eab34c6bef8c5a799 (patch) | |
| tree | 1f91f6a79dd17bb39a8212ce80e8f610d7141848 /widget | |
| parent | 67e181ce7bad516d2ff8fc34c989af2435fdc7b4 (diff) | |
| download | iced-fdcec0319757d2f87c82787eab34c6bef8c5a799.tar.gz iced-fdcec0319757d2f87c82787eab34c6bef8c5a799.tar.bz2 iced-fdcec0319757d2f87c82787eab34c6bef8c5a799.zip | |
Don't consume unused scroll events (#2397)
* Initial Commit
* Update scrollable.rs
* Use `let _ = ` instead of `_ =` for consistency
---------
Co-authored-by: Héctor Ramón Jiménez <hector@hecrj.dev>
Diffstat (limited to '')
| -rw-r--r-- | widget/src/scrollable.rs | 84 | 
1 files changed, 45 insertions, 39 deletions
| diff --git a/widget/src/scrollable.rs b/widget/src/scrollable.rs index 626cd07f..cdc143a2 100644 --- a/widget/src/scrollable.rs +++ b/widget/src/scrollable.rs @@ -435,15 +435,17 @@ where                  state.scroll(delta, self.direction, bounds, content_bounds); -                notify_on_scroll( +                event_status = if notify_on_scroll(                      state,                      &self.on_scroll,                      bounds,                      content_bounds,                      shell, -                ); - -                event_status = event::Status::Captured; +                ) { +                    event::Status::Captured +                } else { +                    event::Status::Ignored +                };              }              Event::Touch(event)                  if state.scroll_area_touched_at.is_some() @@ -481,7 +483,8 @@ where                              state.scroll_area_touched_at =                                  Some(cursor_position); -                            notify_on_scroll( +                            // TODO: bubble up touch movements if not consumed. +                            let _ = notify_on_scroll(                                  state,                                  &self.on_scroll,                                  bounds, @@ -516,7 +519,7 @@ where                              content_bounds,                          ); -                        notify_on_scroll( +                        let _ = notify_on_scroll(                              state,                              &self.on_scroll,                              bounds, @@ -554,7 +557,7 @@ where                          state.y_scroller_grabbed_at = Some(scroller_grabbed_at); -                        notify_on_scroll( +                        let _ = notify_on_scroll(                              state,                              &self.on_scroll,                              bounds, @@ -587,7 +590,7 @@ where                              content_bounds,                          ); -                        notify_on_scroll( +                        let _ = notify_on_scroll(                              state,                              &self.on_scroll,                              bounds, @@ -625,7 +628,7 @@ where                          state.x_scroller_grabbed_at = Some(scroller_grabbed_at); -                        notify_on_scroll( +                        let _ = notify_on_scroll(                              state,                              &self.on_scroll,                              bounds, @@ -965,51 +968,54 @@ pub fn scroll_to<Message: 'static>(      Command::widget(operation::scrollable::scroll_to(id.0, offset))  } +/// Returns [`true`] if the viewport actually changed.  fn notify_on_scroll<Message>(      state: &mut State,      on_scroll: &Option<Box<dyn Fn(Viewport) -> Message + '_>>,      bounds: Rectangle,      content_bounds: Rectangle,      shell: &mut Shell<'_, Message>, -) { -    if let Some(on_scroll) = on_scroll { -        if content_bounds.width <= bounds.width -            && content_bounds.height <= bounds.height -        { -            return; -        } +) -> bool { +    if content_bounds.width <= bounds.width +        && content_bounds.height <= bounds.height +    { +        return false; +    } -        let viewport = Viewport { -            offset_x: state.offset_x, -            offset_y: state.offset_y, -            bounds, -            content_bounds, -        }; +    let viewport = Viewport { +        offset_x: state.offset_x, +        offset_y: state.offset_y, +        bounds, +        content_bounds, +    }; -        // Don't publish redundant viewports to shell -        if let Some(last_notified) = state.last_notified { -            let last_relative_offset = last_notified.relative_offset(); -            let current_relative_offset = viewport.relative_offset(); +    // Don't publish redundant viewports to shell +    if let Some(last_notified) = state.last_notified { +        let last_relative_offset = last_notified.relative_offset(); +        let current_relative_offset = viewport.relative_offset(); -            let last_absolute_offset = last_notified.absolute_offset(); -            let current_absolute_offset = viewport.absolute_offset(); +        let last_absolute_offset = last_notified.absolute_offset(); +        let current_absolute_offset = viewport.absolute_offset(); -            let unchanged = |a: f32, b: f32| { -                (a - b).abs() <= f32::EPSILON || (a.is_nan() && b.is_nan()) -            }; +        let unchanged = |a: f32, b: f32| { +            (a - b).abs() <= f32::EPSILON || (a.is_nan() && b.is_nan()) +        }; -            if unchanged(last_relative_offset.x, current_relative_offset.x) -                && unchanged(last_relative_offset.y, current_relative_offset.y) -                && unchanged(last_absolute_offset.x, current_absolute_offset.x) -                && unchanged(last_absolute_offset.y, current_absolute_offset.y) -            { -                return; -            } +        if unchanged(last_relative_offset.x, current_relative_offset.x) +            && unchanged(last_relative_offset.y, current_relative_offset.y) +            && unchanged(last_absolute_offset.x, current_absolute_offset.x) +            && unchanged(last_absolute_offset.y, current_absolute_offset.y) +        { +            return false;          } +    } +    if let Some(on_scroll) = on_scroll {          shell.publish(on_scroll(viewport)); -        state.last_notified = Some(viewport);      } +    state.last_notified = Some(viewport); + +    true  }  #[derive(Debug, Clone, Copy)] | 
