Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yqritc/RecyclerView-MultipleViewTypesAdapter
Android library defining adapter classes of RecyclerView to manage multiple view types
https://github.com/yqritc/RecyclerView-MultipleViewTypesAdapter
Last synced: 2 months ago
JSON representation
Android library defining adapter classes of RecyclerView to manage multiple view types
- Host: GitHub
- URL: https://github.com/yqritc/RecyclerView-MultipleViewTypesAdapter
- Owner: yqritc
- License: apache-2.0
- Created: 2015-03-24T05:39:35.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2018-05-03T21:01:34.000Z (over 6 years ago)
- Last Synced: 2024-10-15T10:16:30.824Z (3 months ago)
- Language: Java
- Homepage:
- Size: 4.35 MB
- Stars: 413
- Watchers: 29
- Forks: 93
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- -awesome-android-ui - RecyclerView-MultipleViewTypesAdapter - 2.0) | <img src="/art/RecyclerView-MultipleViewTypesAdapter.gif" width="49%"> (Index `(light-weight pages)`)
- awesome-android-ui - RecyclerView-MultipleViewTypesAdapter - 2.0) | <img src="/art/RecyclerView-MultipleViewTypesAdapter.gif" width="49%"> (Index `(light-weight pages)`)
- awesome-android-ui - RecyclerView-MultipleViewTypesAdapter - 2.0) | <img src="/art/RecyclerView-MultipleViewTypesAdapter.gif" width="49%"> (Index)
- awesome-android-ui - https://github.com/yqritc/RecyclerView-MultipleViewTypesAdapter
README
# RecyclerView-MultipleViewTypeAdapter
[![Android Arsenal](https://img.shields.io/badge/Android%20Arsenal-MultipleViewTypesAdapter-brightgreen.svg?style=flat)](http://android-arsenal.com/details/1/1703)
[![License](https://img.shields.io/badge/license-Apache%202-blue.svg)](https://www.apache.org/licenses/LICENSE-2.0)
[![Download](https://api.bintray.com/packages/yqritc/maven/recyclerview-multiple-viewtypes-adapter/images/download.svg)](https://bintray.com/yqritc/maven/recyclerview-multiple-viewtypes-adapter/_latestVersion)RecyclerView adapter classes for managing multiple view types
![Sample](/sample/sample.gif)
# Release Note
[Release Note] (https://github.com/yqritc/RecyclerView-MultipleViewTypesAdapter/releases)
# Gradle
```
repositories {
jcenter()
}dependencies {
compile 'com.yqritc:recyclerview-multiple-viewtypes-adapter:1.1.0'
}
```# About this library
The standard way to handle view creation and data binding logics for RecyclerView is to define the single adapter class extending RecyclerView.Adapter.
If you need to handle simple view type, you will not get in trouble.
But if you need to handle the multiple complex view types, writing logic in single adapter class causes unmaintainable source code.
So, this library separates the logic for each view type into single class (DataBinder), and change the role of adapter class (DataBindAdapter) to manage these DataBinder classes.
By using this library, the implementation would be simple and clear, and also source code for each view type would be maintenable and reusable.# Usage
### 1. Create DataBinder
Define class extending DataBinder for each view type.
DataBinder class is used to bind view and data.Please refer the [binder samples](/sample/src/main/java/com/yqritc/recyclerviewmultipleviewtypesadapter/sample/binder) for usage.
### 2. Create DataBindAdapter
Create adapter class to manage DataBinder classes.
Use (or extend) ListBindAdapter (or EnumListBindAdapter) if the order of view types used for recyclerview is in sequence.
If the order of view types is complex, create class by extending EnumMapBindAdapter or DataBindAdapter.Please refer the [adapter samples](/sample/src/main/java/com/yqritc/recyclerviewmultipleviewtypesadapter/sample/adapter) for usage.
### 3. Set adapter for recyclerview
# License
```
Copyright 2015 yqritcLicensed 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.
```