Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yqritc/RecyclerView-FlexibleDivider
Android library providing simple way to control divider items (ItemDecoration) of RecyclerView
https://github.com/yqritc/RecyclerView-FlexibleDivider
Last synced: 2 months ago
JSON representation
Android library providing simple way to control divider items (ItemDecoration) of RecyclerView
- Host: GitHub
- URL: https://github.com/yqritc/RecyclerView-FlexibleDivider
- Owner: yqritc
- License: apache-2.0
- Created: 2015-01-15T15:09:34.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2023-08-23T10:06:19.000Z (over 1 year ago)
- Last Synced: 2024-10-15T10:06:30.920Z (3 months ago)
- Language: Java
- Homepage:
- Size: 3.62 MB
- Stars: 2,400
- Watchers: 48
- Forks: 385
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- -awesome-android-ui - RecyclerView-FlexibleDivider - 2.0) | <img src="/art/RecyclerView-FlexibleDivider.png" width="49%"> <img src="/art/RecyclerView-FlexibleDivider2.png" width="49%"> (Index `(light-weight pages)`)
- awesome-android-ui - RecyclerView-FlexibleDivider - 2.0) | <img src="/art/RecyclerView-FlexibleDivider.png" width="49%"> <img src="/art/RecyclerView-FlexibleDivider2.png" width="49%"> (Index `(light-weight pages)`)
- awesome-android-ui - RecyclerView-FlexibleDivider - 2.0) | <img src="/art/RecyclerView-FlexibleDivider.png" width="49%"> <img src="/art/RecyclerView-FlexibleDivider2.png" width="49%"> (Index)
- awesome-android-ui - https://github.com/yqritc/RecyclerView-FlexibleDivider
- awesome-android-ui - https://github.com/yqritc/RecyclerView-FlexibleDivider
README
# RecyclerView-FlexibleDivider
[![Android Arsenal](https://img.shields.io/badge/Android%20Arsenal-RecyclerView--FlexibleDivider-brightgreen.svg?style=flat)](https://android-arsenal.com/details/1/1418)
[![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-flexibledivider/images/download.svg)](https://bintray.com/yqritc/maven/recyclerview-flexibledivider/_latestVersion)Android library providing simple way to control divider items of RecyclerView
![Simple Divider](/sample/sample1.gif) ![Complex Divider](/sample/sample2.gif)
# Release Note
[Release Note] (https://github.com/yqritc/RecyclerView-FlexibleDivider/releases)
# Gradle
```groovy
repositories {
jcenter()
}dependencies {
compile 'com.yqritc:recyclerview-flexibledivider:1.4.0'
}
```# Usage
The following is the simplest usage.
Drawing a divider drawable retrieved from android.R.attr.listDivider between each cell.
```java
RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerview);
recyclerView.addItemDecoration(new HorizontalDividerItemDecoration.Builder(this).build());
```| ItemDecoration | Usage |
|:------------------|:----------|
| HorizontalDividerItemDecoration | For layout manager having vertical orientation to draw horizontal divider |
| VerticalDividerItemDecoration | For layout manager having horizontal orientation to draw vertical divider |
_*Please note that you can only set one of above item decorations at a time._If you want to set color, size and margin values, you can specify as the followings.
```java
RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerview);
recyclerView.addItemDecoration(
new HorizontalDividerItemDecoration.Builder(this)
.color(Color.RED)
.sizeResId(R.dimen.divider)
.marginResId(R.dimen.leftmargin, R.dimen.rightmargin)
.build());
```Instead of setting color and size, you can set paint object.
```java
Paint paint = new Paint();
paint.setStrokeWidth(5);
paint.setColor(Color.BLUE);
paint.setAntiAlias(true);
paint.setPathEffect(new DashPathEffect(new float[]{25.0f, 25.0f}, 0));
recyclerView.addItemDecoration(
new HorizontalDividerItemDecoration.Builder(this).paint(paint).build());
```Also 9patch drawable can be used for drawing divider.
```java
RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerview);
recyclerView.addItemDecoration(new HorizontalDividerItemDecoration.Builder(this)
.drawable(R.drawable.sample)
.size(15)
.build());
```If you want to customize divider depending on the position, implement the following interfaces.
### List of provider
The following providers can be implemented and controllable for each divider drawn between cells.
Please refer to ComplexAdapter class in the [sample](/sample/src/main/java/com/yqritc/recyclerviewflexibledivider/sample) for the usage of providers in detail.- ColorProvider
Provide color for divider- PaintProvider
Provide paint object for divider line to draw.- DrawableDivider
Provide drawable object for divider line- SizeProvider
Provide height for horizontal divider, width for vertical divider.- VisibilityProvider
Enables you to control the visibility of dividers.- MarginProvider for horizontal divider (vertical list)
Enables you to specify left and right margin of divider.- MarginProvider for vertical divider (horizontal list)
Enables you to specify top and bottom margin of divider.**For GridLayoutManager**, the position parameter of above providers is group index of items.
So, control your divider based on [group index](http://developer.android.com/intl/ja/reference/android/support/v7/widget/GridLayoutManager.SpanSizeLookup.html#getSpanGroupIndex(int, int)) instead of the position of items.### Optional
- Builder.showLastDivider
Draw divider line at the end of last item in RecyclerView.
If you enable this, the range of position parameter of providers listed above is 0 to itemCount-1.
Otherwise, the range is 0 to itemCount-2.- Builder.positionInsideItem
Draw divider inside items.
If you want to follow [material design guideline](https://www.google.com/design/spec/components/dividers.html#dividers-specs), enable this feature.### Note
- When neither of color, paint, drawable is set, default divider retrieved from android.R.attr.listDivider will be used.
- When you set Paint, you must use setColor and setStrokeWidth methods of paint class.
- If you want to use DashPathEffect, please note the following issue.
https://code.google.com/p/android/issues/detail?id=29944##### _Looking for custom ItemDecoration to achieve equal column space for GridLayoutManager?_
Check out [https://gist.github.com/yqritc/ccca77dc42f2364777e1](https://gist.github.com/yqritc/ccca77dc42f2364777e1)# License
```
Copyright 2016 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.
```