Awesome
RecyclerItemDecoration
RecyclerItemDecoration allows you to draw divider between items in recyclerview with multiple ViewType without considering items' positions!
When using recyclerView with different ViewType, you either have only one simple divider or different types of dividers. When you want to draw different dividers between recyclerView's items, basically you must consider items' position; often you need to have separate ItemDecoration's behaviors declared in your code using switch cases or if statements. For example, each time items' position changes happen, you must rewrite ItemDecoration's behaviors.
You don't need to think about items' position! You need to care about their ViewType!!
Image
Support
- LinearLayoutManager
- Vertical
- Horizontal
- Horizontal(Reverse)
Gradle
implementation 'com.github.magiepooh:recycler-itemdecoration:1.1.1@aar'
How To Use
RecyclerView.ItemDecoration decoration = ItemDecorations.vertical(this)
.first(R.drawable.shape_decoration_green_h_16)
.type(DemoViewType.LANDSCAPE_TILE.ordinal(), R.drawable.shape_decoration_cornflower_lilac_h_8)
.type(DemoViewType.LANDSCAPE_ITEM.ordinal(), R.drawable.shape_decoration_gray_h_12_padding)
.type(DemoViewType.LANDSCAPE_DESCRIPTION.ordinal(), R.drawable.shape_decoration_red_h_8)
.last(R.drawable.shape_decoration_flush_orange_h_16)
.create();
recyclerView.addItemDecoration(decoration);
Credit
- recyclerview-binder by Satoru Fujiwara
License
Copyright (C) 2015 magiepooh
Copyright (C) 2013 The Android Open Source Project
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.