Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sergejsha/pinned-section-listview
Easy to use ListView with pinned sections for Android.
https://github.com/sergejsha/pinned-section-listview
Last synced: 3 months ago
JSON representation
Easy to use ListView with pinned sections for Android.
- Host: GitHub
- URL: https://github.com/sergejsha/pinned-section-listview
- Owner: sergejsha
- Archived: true
- Created: 2013-05-12T13:22:19.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2020-02-23T15:16:35.000Z (almost 5 years ago)
- Last Synced: 2024-05-22T06:10:13.689Z (7 months ago)
- Language: Java
- Size: 806 KB
- Stars: 2,597
- Watchers: 171
- Forks: 811
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-github-android-ui - Pinned Section Listview - 便于使用的ListView (ListView)
README
Easy to use ListView with pinned sections for Android 2.1 and higher. Pinned section is a header view which sticks to the top
of the list until at least one item of that section is visible.![Screenshot 1](web/screen1.png)
![Screenshot 2](web/screen2.png)
![Screenshot 3](web/screen3.png)# Features
This list properly implements many features which are missing from other implementations. These are
* Fast scroll
* Headers and footers
* Clickable pinned sectionsBesides this it doesn't create any unnecessary views, layouts etc. It's really lean.
Watch [this video][1] to see `PinnedSectionListView` in action.
# Usage example
1. Replace standard `ListView` with `de.halfbit.pinnedsection.PinnedSectionListView` in your `layout.xml` file.
```xml
```
2. Extend your `ListAdapter` in a way that it implements `PinnedSectionListAdapter` interface, in addition to
what it already implements. Basically you need to add a single `isItemViewTypePinned(int viewType)`
method. This method must return `true` for all view types which have to be pinned.```java
// Our adapter class implements 'PinnedSectionListAdapter' interface
class MyPinnedSectionListAdapter extends BaseAdapter
implements PinnedSectionListAdapter {
...
// We implement this method to return 'true' for all view types we want to pin
@Override
public boolean isItemViewTypePinned(int viewType) {
return viewType == ;
}
}
```That's all. You are done! A working example can also be found in `example` folder.
# Use with Gradle
Add this to your module-level `build.gradle`:
```groovy
dependencies {
compile "de.halfbit:pinned-section-listview:1.0.0"
}
```Used by
=======
Let us know if you use this library in your application and we will mention it here.[Grocery Sum][2]
[Slack][3]
License
=======Copyright 2013-2016 Sergej Shafarenka, halfbit.de
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.[1]: http://www.youtube.com/watch?v=mI3DpuoIIhQ
[2]: https://play.google.com/store/apps/details?id=org.codechimp.grocerysum
[3]: https://play.google.com/store/apps/details?id=com.Slack