RecyclerView 设置item间距

设置LinearLayoutManager间距
1、继承RecyclerView.ItemDecoration,实现getItemOffsets方法

public class LinearSpacingItemDecoration extends RecyclerView.ItemDecoration {
 
    private int spacing;//间距padding
 
    public LinearSpacingItemDecoration(Context context, int spacings) {
        //获取需要设置的间距值dp,这里不写死,调用时传过来
//        spacing = context.getResources().getDimensionPixelSize(R.dimen.d10);
        spacing = spacings;
    }
 
    @Override
    public void getItemOffsets(@NonNull Rect outRect, @NonNull View view, @NonNull RecyclerView parent, @NonNull RecyclerView.State state) {
        super.getItemOffsets(outRect, view, parent, state);
//        outRect.top = spacing;//item上边的间距
//        outRect.left = spacing;//左边间距
//        outRect.right = spacing;//右边间距
        outRect.bottom = spacing;//设置bottom padding
    }
}
2、然后在设置adapter之前添加上:

mRecyclerView.addItemDecoration(new LinearSpacingItemDecoration(spacings));
 设置GridLayoutManager间距(网格布局):
1、和上边设置一样,继承RecyclerView.ItemDecoration,实现getItemOffsets方法

public class GridSpacingItemDecoration extends RecyclerView.ItemDecoration {
    private int spanCount; //列数
    private int spacing; //间隔
    private boolean isIncludeEdge; //是否有边缘
 
    public GridSpacingItemDecoration(int spanCount, int spacing, boolean isIncludeEdge) {
        this.spanCount = spanCount;
        this.spacing = spacing;
        this.isIncludeEdge = isIncludeEdge;
    }
 
    @Override
    public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
 
        //判断你有几列,设置item
        int position = parent.getChildAdapterPosition(view); // item position
        int column = position % spanCount; // item column
 
        if (isIncludeEdge) {
            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
            }
        }
    }
 
}

2、调用:

mRecyclerView.addItemDecoration(new GridSpacingItemDecoration(Count, spacing, isIncludeEdge));
即可。
 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值