Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Flywheel/momentum scrolling #69

Open
gnprice opened this issue Apr 18, 2023 · 1 comment
Open

Flywheel/momentum scrolling #69

gnprice opened this issue Apr 18, 2023 · 1 comment
Labels
a-msglist The message-list screen, except what's label:a-content upstream Would benefit from work in Flutter or another upstream
Milestone

Comments

@gnprice
Copy link
Member

gnprice commented Apr 18, 2023

On Android, the platform provides two different scrolling behaviors: one for native scrollables, and one for browsers and webviews. The difference is that the browser scrolling includes a "flywheel" or "momentum" behavior. (Details in chat.) This is very useful when scrolling through a ton of content — hence the usage in browsers — because it means that with several quick flicks of their finger the user can get the page scrolling very quickly, and scrolling very far before it comes to a stop.

Flutter's default scrolling behavior on Android (after flutter/flutter#120420 and flutter/flutter#122338) closely matches that of native Android scrollables, without a flywheel. There currently isn't an option for the flywheel scrolling found in Android webviews.

For the Zulip message list, flywheel scrolling is probably useful for much the same reason it is in a browser: sometimes the content is very long and you want to scan through it quickly. So it'd be good to try it out.

Props to @terpimost for detecting that there was something about the "overall max speed of scroll" that didn't feel right and would be good to compare to "browser based scroll" in particular — I think the difference he was sensing is probably exactly this. (I learned about this pair of contrasting behaviors from studying the Android scrolling code back in February, around the time of flutter/flutter#120420 and the related issues I filed.)

Implementation

Probably the right home for that behavior is as an option in Flutter upstream. It's a behavior that Android users are accustomed to — in fact most Android users probably do most of their scrolling in contexts that have this behavior, because large quantities of content calling for lots of scrolling tend to be web pages (and even when they're not overtly so, are often presented in a webview.) So when a Flutter app has a scrollable that's more in the nature of "a lot of content presented for reading, akin to a long web page" than "a list of items in a UI", probably the behavior that will best match Android users' expectations will be flywheel scrolling. Which means it should be an option that Flutter developers can readily choose in their apps.

Specifically, this probably means either a new subclass of ScrollPhysics, or a new feature on the existing subclass ClampingScrollPhysics which provides the Android behavior. Either way, the appropriate ScrollPhysics can then be passed in places like the physics parameter of ListView.builder (which becomes ScrollView.physics).

@gnprice gnprice added the a-msglist The message-list screen, except what's label:a-content label May 27, 2023
@gnprice gnprice added this to the Launch milestone Jun 15, 2023
@gnprice gnprice modified the milestones: Launch, Post-launch Jul 31, 2024
@gnprice gnprice modified the milestones: M6: Post-launch, M7: Future Nov 21, 2024
@gnprice gnprice added the upstream Would benefit from work in Flutter or another upstream label Nov 22, 2024
@gnprice
Copy link
Member Author

gnprice commented Dec 19, 2024

This came up a couple of weeks ago when talking to a longtime Zulip user trying the new app. He scrolled through some message history, fling-scrolling repeatedly in quick succession, and commented that it felt like it was scrolling slower than in the legacy app.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
a-msglist The message-list screen, except what's label:a-content upstream Would benefit from work in Flutter or another upstream
Projects
Status: No status
Development

No branches or pull requests

1 participant