Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/quiph/RecyclerView-FastScroller
A fully customizable Fast Scroller for the RecyclerView in Android, written in Kotlin
https://github.com/quiph/RecyclerView-FastScroller
android fastscroll fastscroll-recyclerview java kotlin kotlin-android kotlin-library recyclerview scroll scrolling view
Last synced: about 2 months ago
JSON representation
A fully customizable Fast Scroller for the RecyclerView in Android, written in Kotlin
- Host: GitHub
- URL: https://github.com/quiph/RecyclerView-FastScroller
- Owner: quiph
- License: apache-2.0
- Archived: true
- Created: 2018-06-27T15:07:37.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2022-05-18T08:07:52.000Z (over 2 years ago)
- Last Synced: 2024-08-01T01:30:49.645Z (4 months ago)
- Topics: android, fastscroll, fastscroll-recyclerview, java, kotlin, kotlin-android, kotlin-library, recyclerview, scroll, scrolling, view
- Language: Kotlin
- Homepage:
- Size: 4.88 MB
- Stars: 846
- Watchers: 22
- Forks: 69
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-kotlin - RecyclerView-FastScroller - A fully customizable Fast Scroller for the RecyclerView in Android, written in Kotlin (Libraries)
README
# RecyclerViewFastScroller
![Github release](https://img.shields.io/github/release/quiph/recyclerview-fastscroller.svg)
![Maven Central](https://img.shields.io/maven-central/v/com.quiph.ui/recyclerviewfastscroller)
![Code size](https://img.shields.io/github/languages/code-size/quiph/recyclerview-fastscroller.svg?colorB=4bc51d)
[![Android Weekly #317](https://img.shields.io/badge/Android%20Weekly-%23317-1eafe6.svg)](https://androidweekly.net/issues/issue-317)
[![Kotlin Weekly #101](https://img.shields.io/badge/Kotlin%20Weekly-%23101-9e5ef2.svg)](https://mailchi.mp/kotlinweekly/kotlin-weekly-100-sytgpg6yuv?e=55ca282aa1)A simple, easy to use and configurable fast scroller for `RecyclerView`
## Adding the dependency
```groovy
implementation 'com.quiph.ui:recyclerviewfastscroller:1.0.0'
```
## Java-only project?
As Kotlin compiles to Java, there's no need to externally add the Kotlin runtime or any other Kotlin dependencies when using this. Also the library is **100% compatible with Java** and requires **no migration** of the base project to Kotlin.## Usage:
The base layout type for this fast scroller is a `RelativeLayout` so creating a simple
vertical fast scroller is as simple as adding elements as children to the `RecyclerViewFastScroller` layout tag
```xml
....
other view tags can also come here
....```
Since the fast scroller extends a `RelativeLayout` other view tags can also be added to it, with the rule being that
the `RecyclerView` on which the fast scroller functionality needs to be added be the first element in the `ViewGroup`#### Programmatically adding the RecyclerView
If the `RecyclerView` to be added to the fast scroller is not available during layout creation time, the same can be done programmatically
by calling the `attachFastScrollerToRecyclerView` method on the `RecyclerView`### Linking with items:
To reflect the item on the index of the top-most visible item, make the adapter implement the `OnPopupTextUpdate` interface, which overrides the method
`onChange(int index)` which passes the index of the element whose info needs to be displayed in the popup.The `CharSequence` to be displayed should be returned in this method.
Ex:
```kotlin
class MyAdapter : RecyclerView.Adapter, OnPopupTextUpdate{
// ....
override fun onChange(position: Int): CharSequence {
val header = // compute value for header using position
return header
}
}
```### Getting fast scroller callbacks:
To get the callback from the fast scroller for different states, a listener can be added using the `setHandleStateListener` which accepts an interface of type
`HandleStateListener` which has the following callback methods:
* `onEngaged` - Called when the fast scroller is engaged
* `onDragged` - Called on every movement of the fast scroller, note: this does not get called when the handle moves programmatically, i.e when then the Scroll is programmatic
* `onReleased` - Called when the fast scroller is released.## Customizable XML Attributes:
* `trackDrawable` - Adds a custom drawable to the scrolling track, defaults to `null`
* `handleDrawable` - Adds a custom drawable to the scrolling handle of the fast scroller
* `popupDrawable` - Adds a custom drawable to the popup used to show the index of the element fast scrolled at
* `popupTextStyle` - Sets the style for the popup text shown
* `fastScrollEnabled` - Boolean flag to enable/ disable the fast scroller, the fast scroller view and track are hidden when disabled
* `popupPosition` - An enum to define where the popup should be shown for the fast scroller, one of
1. `beforeTrack` - Positions the popup to be shown before the scroll track
2. `afterTrack` - Position it after the scroll track
* `handleWidth` - Use to custom set the width of the fast scroll handle - Defaults to 18dp
* `handleHeight` - Use to custom set the height of the fast scroll handle - Defaults to 18dp
* `addLastItemPadding` - By default the last item of the `RecyclerView` associated with the fast scroller has an extra padding of the height of the first visible item found, to disable this behaviour set this as `false`
* `supportSwipeToRefresh` - To support smooth scrolling for RecyclerViews nested within a `SwipeRefreshLayout`
* `trackMarginStart` - Adds a start margin to the track of the fastscroller
* `trackMarginEnd` - Adds a end margin to the track of the fastscroller
* `handleVisibilityDuration` - Adds an option to specify the duration to hide the fastscroller handle, defaults to -1, which doesn't hide it
* `handleHasFixedSize` - TODO - currently setting this to false doesn't do anything, as the size of the handle is independent of the item count
* `fastScrollDirection` - TODO - currently the fast scroller only works in the `vertical` direction## Advanced usage:
* Different color popups can be shown based on the position of the item shown, to do this, implement the `OnPopupViewUpdate` which overrides the
`onUpdate(position: Int, popupTextView: TextView)` which return void, but has an instance of the `TextView` used in popup, this can be used to change the background.Check the sample file [AdvancedFragment](https://github.com/quiph/RecyclerView-FastScroller/blob/master/sample/src/main/java/com/qtalk/sample/fragments/AdvancedFragment.kt) and [AdvancedAdapter](https://github.com/quiph/RecyclerView-FastScroller/blob/master/sample/src/main/java/com/qtalk/sample/adapters/AdvancedAdapter.kt) for example usage
Ex:
```kotlin
class MyAdapter : RecyclerView.Adapter, OnPopupViewUpdate{override fun onChange(position: Int, popupTextView: TextView) {
// Do something with the TextView here
popupTextView.background = Color.RED // change some values etc
}
}
```
The `popupDrawable` attribute and the `popupTextStyle` attributes can be used to create different kinds of elements, shapes and text appearance combinations, for example like the popup similar to the Google Dialer app:Check the sample to view the implementation. Many such shapes and text styles can be created.
#### Proguard:
There is no need for any additional proguard rules when using this.## Contributing
Thank you for your interest :)
To start contributing, you can check out the [issues](https://github.com/quiph/RecyclerView-FastScroller/labels/good%20first%20issue) section with the tag "Good first issue" to start working on the low-hanging fruits. Once you feel comfortable to contribute, fork the project and raise a PR, we'd be happy to review it <3
### Creating a Pull Request
Our team follows [the GitHub pull request workflow](https://guides.github.com/introduction/flow/): fork, branch, commit,
pull request, review, merge. If you're new to GitHub, check out [the official
guides](https://guides.github.com/) for more information.An example commit message summary looks like, `For #5: Upgrade gradle to v1.3.0`.
Please follow these guidelines for your pull requests:
- All Pull Requests should address an issue. If your pull request doesn't have an
issue, file it!
- GitHub search defaults to issues, not PRs, so ensuring there is an issue for your PR
means it'll be easier to find
- The commit message summary should briefly describe what code changed in the commit, *not
the issue you're fixing.*
- We encourage you to use the commit message body to elaborate what changed and why
- Include the issue number in your commit messages. This links your PR to the issue it's
intended to fix.
- If your PR closes an issue, include `Closes #...` in one of your commit messages. This
will automatically close the linked issue [more info](https://help.github.com/articles/closing-issues-using-keywords/).
- If your PR has to go through a longer process, for example QA verification, use the
`For #...` syntax to allow the linked issue to be closed at a later, more appropriate time.
- Prefer "micro commits".
- A micro commit is a small commit that generally changes one thing.
A single Pull Request may comprise of multiple incremental micro commits.
- A series of micro commits should tell a story. For example, if your goal is to add a new
icon to the toolbar, you can make a commit to add the icon asset and then make a commit to
use the icon in the code.
- Commits should generally not undo the work of previous commits in the same PR.
- If you're not comfortable making micro commits, it's okay to begin contributing without
them.
- Add a reviewer to ensure someone sees, and reviews, your pull request so it can be merged
- If the tests fail, please try to fix them! Keeping the tests passing ensures our code isn't
broken and the code is unlikely to get merged without passing tests. If you run into trouble,
ask for help!
- If there are UI changes, include a screenshot so UX can also do a visual review
- When in doubt, look at the closed PRs in the repository to follow as an example or ask
us online!If your code is not approved, address the suggested comments, push your changes, and re-request
review from your reviewer again.## Merging
After your code has been approved and the tests pass, your code will be merged into master
by the core team. When merging, we use GitHub's "Rebase and merge":
- We keep a linear git history for readability
- We prefer incremental commits to remain in the history
- It's easier to read, helps with bisection, and matches repo state during review.### Building the source:### Building the source
To build the `aar` using using gradle, simply run the build command, `./gradlew build` this will build and place the aars in the `outputs/aar` folder inside the library
module. The final path may look something like:
```groovy
"${rootProject.projectDir}/recyclerviewfastscroller/build/outputs/aar"
```This path has a number of aars in it, (debug and release variants namely). To use these aars in the sample, simple uncomment the following line in `build.gradle` for sample
```groovy
// implementation files("${rootProject.projectDir}/recyclerviewfastscroller/build/outputs/aar/recyclerviewfastscroller-release.aar")
```Don't forget to comment the project/ module dependency above it. Re-sync the project and run the sample to test how the compiled version would behave.
#### Uploading to maven central:
We will be using the Nexus Software Repository for pushing our aars to maven-central, there are different methods to do this,
another simple way is to upload to bintray and then push to maven-central from there, which one to use can completely depend upon the developer.Detailed explanation [here](https://gist.github.com/shahsurajk/471a10b63207e44bbbaa4badd9706770).
Once the environment is setup as mentioned in the gist, run the following command:
```bash
./gradlew clean build uploadArchives
```#### TODO:
* [ ] Add support for `horizontal` fast scrolling
* [ ] Make handle size flexible to item count in adapter
* [ ] Fix 0 item bug, which makes the fast scroller visible