Step 1. Add the JitPack repository to your build file
Add it in your root build.gradle at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url 'https://jitpack.io' }
}
}
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add it in your build.sbt at the end of resolvers:
resolvers += "jitpack" at "https://jitpack.io"
Add it in your project.clj at the end of repositories:
:repositories [["jitpack" "https://jitpack.io"]]
Step 2. Add the dependency
dependencies {
implementation 'com.github.shamylzakariya:stickyheaders:0.7.11'
}
<dependency>
<groupId>com.github.shamylzakariya</groupId>
<artifactId>stickyheaders</artifactId>
<version>0.7.11</version>
</dependency>
libraryDependencies += "com.github.shamylzakariya" % "stickyheaders" % "0.7.11"
:dependencies [[com.github.shamylzakariya/stickyheaders "0.7.11"]]
Adapter and LayoutManager for Android RecyclerView which enables sticky header positioning.
minSdkVersion: 14
compile 'org.zakariya.stickyheaders:stickyheaders:0.7.10'
StickyHeaders are section headers in a RecyclerView which are positioned "stickily" to the top of the scrollview during scrolling. A common use-case is an address book where the list of people's last names are grouped into sections by the first letter of the last name, and the header for each section shows that letter.
For example:
StickyHeaders also supports a callback (org.zakariya.stickyheaders.StickyHeaderLayoutManager.HeaderPositionChangedCallback
) when a header becomes "sticky" or returns to normal positioning. For example, it is used here to set the elevation on the header to cast a subtle drop shadow when the header is in sticky position.
For example:
To use StickyHeaders, you need to do two things.
org.zakariya.stickyheaders.SectioningAdapter
org.zakariya.stickyheaders.StickyHeaderLayoutManager
to your recyclerview.RecyclerView.Adapter::notify*
methods, instead, call the corresponding methods in org.zakariya.stickyheaders.SectioningAdapter::notifySection*
. The reason for this is SectioningAdapter
maintains internal state, and the notifySection*
methods are tailored for adding and removing sections, adding and removing items from sections, etc.androidx.recyclerview.*
androidx.recyclerview.widget.LinearLayoutManager
. it works fine, and could be a good way to implement a list like at the root of Android's Settings app.