android recyclerview 间距,浅谈Android RecyclerView 间距全适配

浅谈Android RecyclerView 间距全适配

发布时间:2020-08-29 17:32:19

来源:脚本之家

阅读:95

作者:anonymoussf

本文介绍了Android RecyclerView 间距全适配,分享给大家,具体如下:

LinearLayoutManager spacing

import android.graphics.Rect;

import android.support.v7.widget.RecyclerView;

import android.view.View;

/**

* Created by anonymous on 2016/9/9 0009.

*

* SpacesItemDecoration

*

* mRecyclerView.addItemDecoration(new SpacesItemDecoration(5));

*/

public class SpacesItemDecoration extends RecyclerView.ItemDecoration {

private int space;

public SpacesItemDecoration(int space) {

this.space = space;

}

@Override

public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {

outRect.left = space;

outRect.right = space;

outRect.bottom = space;

// Add top margin only for the first item to avoid double space between items

if (parent.getChildLayoutPosition(view) == 0) {

outRect.top = space;

} else {

outRect.top = 0;

}

}

}

使用方法很简单,上面注释中也已经给出:

mRecyclerView.addItemDecoration(new SpacesItemDecoration(5));

GridLayoutManager or StaggeredGridLayoutManager spacing

import android.graphics.Rect;

import android.support.v7.widget.RecyclerView;

import android.view.View;

/**

* Created by anonymous on 2016/9/9 0009.

*

* GridSpacingItemDecoration

*

* int spanCount = 3; // 3 columns

* int spacing = 50; // 50px

* boolean includeEdge = false;

* recyclerView.addItemDecoration(new GridSpacingItemDecoration(spanCount, spacing, includeEdge));

*/

public class GridSpacingItemDecoration extends RecyclerView.ItemDecoration {

private int spanCount;

private int spacing;

private boolean includeEdge;

public GridSpacingItemDecoration(int spanCount, int spacing, boolean includeEdge) {

this.spanCount = spanCount;

this.spacing = spacing;

this.includeEdge = includeEdge;

}

@Override

public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {

int position = parent.getChildAdapterPosition(view); // item position

int column = position % spanCount; // item column

if (includeEdge) {

outRect.left = spacing - column * spacing / spanCount; // spacing - column * ((1f / spanCount) * spacing)

outRect.right = (column + 1) * spacing / spanCount; // (column + 1) * ((1f / spanCount) * spacing)

if (position < spanCount) { // top edge

outRect.top = spacing;

}

outRect.bottom = spacing; // item bottom

} else {

outRect.left = column * spacing / spanCount; // column * ((1f / spanCount) * spacing)

outRect.right = spacing - (column + 1) * spacing / spanCount; // spacing - (column + 1) * ((1f / spanCount) * spacing)

if (position >= spanCount) {

outRect.top = spacing; // item top

}

}

}

}

此处不仅对间距进行了处理,而且对spanCount也进行了处理,使用方法:

int spanCount = 3; // 3 columns

int spacing = 50; // 50px

boolean includeEdge = false;

mRecyclerView.addItemDecoration(new GridSpacingItemDecoration(spanCount, spacing, includeEdge));

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值