android开发分割线代码,一个通用的RecyclerView的分割线

Y_DividerItemDecoration

一个通用的RecyclerView的分割线,支持LinearLayoutManager和GridLayoutManager。只要你能描述清楚每个position上下左右分割线的情况,原则上支持任意LayoutManager

df96c79a0056e7acf5f0674e9f007f29.png95c143936c37937328320311a531e2a6.pngdb5c3dc827e62be162dcb3404414a1e3.pngc289a2c007ef52428bb169d1683cc42a.png

Features

LinearLayoutManager和GridViewLayoutManager通用

以每个item的上、下、左、右每条边为控制单位

可以单独控制每边是否显示

可以单独控制每边的颜色

可以单独控制每边的宽度

可以单独控制每边的 startPadding 和 endPadding

Usage

Step 1

将依赖加入你项目的build.gradle中:

compile 'com.yanyusong.y_divideritemdecoration:y_divideritemdecoration:2.0'

Step 2

新建一个对象实现抽象类 Y_DividerItemDecoration ,在 getDivider(int itemPosition) 中定义在itemPosition时条目的分割线情况,有无、颜色、宽度、startpadding 和 endpadding 。

private class DividerItemDecoration extends Y_DividerItemDecoration {

private DividerItemDecoration(Context context) {

super(context);

}

@Override

public Y_Divider getDivider(int itemPosition) {

Y_Divider divider = null;

switch (itemPosition % 2) {

case 0:

//每一行第一个显示rignt和bottom

divider = new Y_DividerBuilder()

.setRightSideLine(true, 0xff666666, 10, 0, 0)

.setBottomSideLine(true, 0xff666666, 20, 0, 0)

.create();

break;

case 1:

//第二个显示Left和bottom

divider = new Y_DividerBuilder()

.setLeftSideLine(true, 0xff666666, 10, 0, 0)

.setBottomSideLine(true, 0xff666666, 20, 0, 0)

.create();

break;

default:

break;

}

return divider;

}

}

Step 3

给RecyclerView添加刚才实现的ItemDecoration

recyclerView.addItemDecoration(new DividerItemDecoration(this));

License

Copyright 2017 yanyusong

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.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值