RecyclerView滑动监听

recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
    /**
     * Callback method to be invoked when the RecyclerView has been scrolled. This will be
     * called after the scroll has completed.
     * This callback will also be called if visible item range changes after a layout
     * calculation. In that case, dx and dy will be 0.
     * @param recyclerView The RecyclerView which scrolled.
     * @param dx           The amount of horizontal scroll.
     * @param dy           The amount of vertical scroll.
     */
    @Override
    public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
        super.onScrolled(recyclerView, dx, dy);
        RecyclerView.LayoutManager manager = recyclerView.getLayoutManager();//获取LayoutManager
        //经过测试LinearLayoutManager和GridLayoutManager有以下的方法,这里只针对LinearLayoutManager
        if (manager instanceof LinearLayoutManager) {
            //经测试第一个完整的可见的item位置,若为0则是最上方那个;在item超过屏幕高度的时候只有第一个item出现的时候为0 ,其他时候会是一个负的值
            //此方法常用作判断是否能下拉刷新,来解决滑动冲突
            int findFirstCompletelyVisibleItemPosition = ((LinearLayoutManager) manager).findFirstCompletelyVisibleItemPosition();
            //最后一个完整的可见的item位置
            int findLastCompletelyVisibleItemPosition =  ((LinearLayoutManager) manager).findLastCompletelyVisibleItemPosition();
            //第一个可见的位置
            int findFirstVisibleItemPosition =  ((LinearLayoutManager) manager).findFirstVisibleItemPosition();
            //最后一个可见的位置
            int findLastVisibleItemPosition =  ((LinearLayoutManager) manager).findLastVisibleItemPosition();

            //如果有滑动冲突--可以用以下方法解决(如果可见位置是position==0的话才能有下拉刷新否则禁掉)
            mSwipeRefreshLayout.setEnabled(findFirstCompletelyVisibleItemPosition==0);
            //在网上还看到一种解决滑动冲突的方法
            int topPosition =
                    (recyclerView == null || recyclerView.getChildCount() == 0) ? 0 : recyclerView.getChildAt(0).getTop();

Log.e("touch", "onScroll:" + topPosition);

mSwipeRefreshLayout.setEnabled(topPosition >= 0);

      }
    }
});

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RecyclerView提供了多种滑动监听的方式,常见的几种方式如下: 1. OnScrollListenerRecyclerView中,可以通过继承RecyclerView.OnScrollListener类,并实现其onScrolled()和onScrollStateChanged()方法来监听滑动事件。 onScrolled()方法会在RecyclerView滚动时不断被调用,可以在其中获取当前RecyclerView的滚动状态,包括当前滚动的距离和方向等信息。 onScrollStateChanged()方法则会在RecyclerView的滚动状态发生变化时被回调,包括停止滚动、开始滚动和正在滚动等状态。 示例代码如下: ```java public class RecyclerViewScrollListener extends RecyclerView.OnScrollListener { @Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); // 获取当前RecyclerView的滚动状态 // dx和dy分别为滚动的距离,可以根据这个值来判断滚动方向 } @Override public void onScrollStateChanged(RecyclerView recyclerView, int newState) { super.onScrollStateChanged(recyclerView, newState); // 获取当前RecyclerView的滚动状态发生变化的状态 // 包括停止滚动、开始滚动和正在滚动等状态 } } ``` 2. RecyclerView.OnFlingListener RecyclerView还提供了一个OnFlingListener监听器,用于监听用户快速滑动的事件。可以通过继承RecyclerView.OnFlingListener类,并实现其onFling()方法来监听快速滑动事件。 示例代码如下: ```java public class RecyclerViewFlingListener extends RecyclerView.OnFlingListener { @Override public boolean onFling(int velocityX, int velocityY) { // 用户快速滑动时会回调这个方法 // velocityX和velocityY分别表示水平和竖直方向的滑动速度 return super.onFling(velocityX, velocityY); } } ``` 3. RecyclerView.addOnScrollListener() 还可以通过RecyclerViewaddOnScrollListener()方法来添加滑动监听器,该方法可以添加多个滑动监听器,可以根据需要选择使用。 示例代码如下: ```java recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() { @Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); // 获取当前RecyclerView的滚动状态 } @Override public void onScrollStateChanged(RecyclerView recyclerView, int newState) { super.onScrollStateChanged(recyclerView, newState); // 获取当前RecyclerView的滚动状态发生变化的状态 } }); recyclerView.addOnFlingListener(new RecyclerView.OnFlingListener() { @Override public boolean onFling(int velocityX, int velocityY) { // 用户快速滑动时会回调这个方法 return super.onFling(velocityX, velocityY); } }); ``` 以上是常见的RecyclerView滑动监听方式,可以根据具体需求选择使用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值