https://github.com/dvdciri/multichoicerecyclerview
Multi choice selection applied on recycler view make life easier
https://github.com/dvdciri/multichoicerecyclerview
multi-choice-selection multi-choice-toolbar multichoiceadapter recyclerview recyclerview-adapter
Last synced: about 1 year ago
JSON representation
Multi choice selection applied on recycler view make life easier
- Host: GitHub
- URL: https://github.com/dvdciri/multichoicerecyclerview
- Owner: dvdciri
- Created: 2015-10-28T12:43:39.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2018-03-29T07:34:44.000Z (about 8 years ago)
- Last Synced: 2025-03-31T10:08:49.002Z (about 1 year ago)
- Topics: multi-choice-selection, multi-choice-toolbar, multichoiceadapter, recyclerview, recyclerview-adapter
- Language: Java
- Homepage:
- Size: 21.6 MB
- Stars: 352
- Watchers: 8
- Forks: 68
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
README
[  ](https://bintray.com/dvd-ciri/maven/MultiChoiceRecyclerView/_latestVersion)
[](https://maven-badges.herokuapp.com/maven-central/cz.jirutka.rsql/rsql-parser)
[](https://android-arsenal.com/details/1/3755)
[](https://circleci.com/gh/dvdciri/MultiChoiceRecyclerView/tree/master)
# Multichoice RecyclerView
Donwload the sample app on the Google Play Store and check out all the features

## Description
This library make life easier when you have to deal with a multi choice selection on recycler view.
## Developed by
**Davide Cirillo**
- Twitter @DvdCiri
- GitHub @dvdciri
- Mail dvd.ciri@gmail.com
If you want to contribute to the project feel free to Fork and create a Pull Request following the general rules for contribution: https://guides.github.com/activities/contributing-to-open-source/
### Thanks for the contribution!
- [Simon Hardt](https://github.com/hardysim)
## How to use
Add the library as dependency
```java
repositories {
jcenter()
}
...
dependencies {
compile 'com.davidecirillo.multichoicerecyclerview:multichoicerecyclerview:2.3.0'
}
```
Extend your adapter to the MultiChoiceAdapter and add it to the RecyclerView as per normal usage
```java
public class MyAdapter extends MultiChoiceAdapter {
public MyAdapter(ArrayList stringList, Context context) {
this.mList = stringList;
this.mContext = context;
}
@Override
public void onBindViewHolder(MySampleToolbarViewHolder holder, int position) {
super.onBindViewHolder(holder, position);
/*
Don't use View.OnClickListener on the "holder.itemView", override defaultItemViewClickListener(...) instead
*/
...
}
}
```
```java
MyAdapter myAdapter = new MyAdapter(mList, context);
mMultiChoiceRecyclerView.setAdapter(myAdapter);
```
**N.B.**
- Do not forget to call **super.onBindViewHolder(holder, position);** when binding the view holder
Customize the activation or deactivation just overriding the setActive(View rootView, boolean state) method of the MultiChoiceAdapter
```java
@Override
public void setActive(View rootView, boolean state) {
//Use View.findViewById(int id) to look for your view in the rootView
if(state){
//Apply your changes
}else{
//Reset your changes
}
}
```
## Features
[Sample features](https://github.com/dvdciri/MultiChoiceRecyclerView/blob/master/FEATURES.md)
## Changelog
[Changelog file](https://github.com/dvdciri/MultiChoiceRecyclerView/blob/master/CHANGELOG.md)
## License
```
Copyright (c) 2014 Davide Cirillo
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 at
http://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.
Come on, don't tell me you read that.
```
