recyclerview 通用gridlayoutmanger itemdecoration 间距。。可以含头部

recyclerview使用的时候,大多数时候会用到复杂布局,一个页面从上到下,有多种布局,spancount不为1,这个时候,用两种recyclerview又很麻烦,所以需要这个itemdecoration来设置间距。。。


先来看一个实例布局。。。

recyclerview 通用gridlayoutmanger itemdecoration 间距。。可以含头部_第1张图片



整个布局除了底部导航栏和上部的toolbar,都是一个recyclerview中,banner 和 中间那块导航栏也是recyclerview的一部分分别是不同的viewtype。。。

很明显,banner和中间那块导航栏并不需要设置间距,而下面的方块的教练信息item需要设置间距,那么怎么办,又要放在一个recyclerview中,只能在设置间距的时候,把除了方块的其他viewtype的间距不设置。。。


看代码


public class GridSpacingItemDecoration extends RecyclerView.ItemDecoration {

    private int spanCount;
    private int spacing;
    private boolean includeEdge;
    private int headerNum;

    public GridSpacingItemDecoration(int spanCount, int spacing, boolean includeEdge, int headerNum) {
        this.spanCount = spanCount;
        this.spacing = spacing;
        this.includeEdge = includeEdge;
        this.headerNum = headerNum;
    }

    @Override
    public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
        int position = parent.getChildAdapterPosition(view) - headerNum; // item position

        if (position >= 0) {
            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
                }
            }
        } else {
            outRect.left = 0;
            outRect.right = 0;
            outRect.top = 0;
            outRect.bottom = 0;
        }
    }
}


头部不设置的有几个部分,就把headernum设置为几

你可能感兴趣的:(fragment,itemdecoration,recyclerview,mulititype)