Android RecyclerView每行显示几个item

内容比较简单直接上代码

1、创建一个 GridItemDecoration 工具类

import android.graphics.Rect;
import android.view.View;

import androidx.recyclerview.widget.RecyclerView;

public class GridItemDecoration extends RecyclerView.ItemDecoration {
 
    private int spanCount;
    private int spacing;
    private boolean includeEdge;
    private boolean includeTopEdge;
    private boolean includeBottomEdge;

    public GridItemDecoration(int spanCount, int spacing, boolean includeEdge) {
        this.spanCount = spanCount;
        this.spacing = spacing;
        this.includeEdge = includeEdge;
        this.includeTopEdge = includeEdge;
        this.includeBottomEdge = includeEdge;
    }

    public GridItemDecoration(int spanCount, int spacing, boolean includeEdge, boolean includeTopEdge, boolean includeBottomEdge) {
        this.spanCount = spanCount;
        this.spacing = spacing;
        this.includeEdge = includeEdge;
        this.includeTopEdge = includeTopEdge;
        this.includeBottomEdge = includeBottomEdge;
    }

    @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 (includeTopEdge) {
                if (position < spanCount) { // top edge
                    outRect.top = spacing;
                }
            }

            if (includeBottomEdge) {
                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、使用方式

 		vb.includeRecyclerView.recyclerView.addItemDecoration(GridItemDecoration(2, ConvertUtils.dp2px(10.0f), true))
        vb.includeRecyclerView.recyclerView.layoutManager = GridLayoutManager(mContext, 2)
        vb.includeRecyclerView.recyclerView.adapter = adapter

没有啦。。去试试吧

除了使用LayoutManager的scrollToPositionWithOffset方法实现RecyclerView定位到指定的item并置顶之外,还有以下几种方法: 1.使用SmoothScroller SmoothScroller是RecyclerView提供的一个平滑滚动的工具类,通过重写其computeScrollVectorForPosition方法和getVerticalSnapPreference方法,可以实现RecyclerView定位到指定的item并置顶。具体实现步骤如下: ```java int position = 10; // 定位的item的position RecyclerView recyclerView = findViewById(R.id.recycler_view); RecyclerView.SmoothScroller smoothScroller = new LinearSmoothScroller(recyclerView.getContext()) { @Override public PointF computeScrollVectorForPosition(int targetPosition) { return new PointF(0, 1); } @Override protected int getVerticalSnapPreference() { return LinearSmoothScroller.SNAP_TO_START; } }; smoothScroller.setTargetPosition(position); recyclerView.getLayoutManager().startSmoothScroll(smoothScroller); ``` 其中,computeScrollVectorForPosition方法返回一个PointF对象,用于指定RecyclerView滚动的方向,这里返回的是(0, 1),表示垂直向下滚动;getVerticalSnapPreference方法用于指定RecyclerView滚动后定位的位置,这里返回的是SNAP_TO_START,表示定位到顶部。 2.使用scrollToPosition方法 scrollToPosition方法可以让RecyclerView滚动到指定位置,但是无法控制定位的偏移量。如果需要置顶,可以在滚动后手动调整RecyclerView的滚动位置。具体实现步骤如下: ```java int position = 10; // 定位的item的position RecyclerView recyclerView = findViewById(R.id.recycler_view); recyclerView.scrollToPosition(position); recyclerView.post(() -> { View itemView = recyclerView.getLayoutManager().findViewByPosition(position); if (itemView != null) { int offsetY = -(recyclerView.getHeight() - itemView.getHeight()) / 2; // 置顶的偏移量 recyclerView.scrollBy(0, offsetY); } }); ``` 其中,scrollToPosition方法可以将RecyclerView滚动到指定位置;post方法用于在RecyclerView绘制完成后获取定位的item的视图,并计算置顶的偏移量;scrollBy方法用于手动调整RecyclerView的滚动位置。 以上是实现RecyclerView定位到指定的item并置顶的几种方法,开发者可以根据实际需求选择合适的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值