Android RecyclerView的滑动监听

1 RecyclerView 的滑动监听

1.1 RecyclerView 设置滑动监听

<span style="color:#000000"><code class="language-java">
mRecyclerView.setOnScrollListener(<span style="color:#000088">new</span> RecyclerView.OnScrollListener() {
    <span style="color:#9b859d">@Override</span>
    <span style="color:#000088">public</span> <span style="color:#000088">void</span> <span style="color:#009900">onScrollStateChanged</span>(RecyclerView recyclerView, <span style="color:#000088">int</span> newState) {
        <span style="color:#000088">super</span>.onScrollStateChanged(recyclerView, newState);
    }

    <span style="color:#9b859d">@Override</span>
    <span style="color:#000088">public</span> <span style="color:#000088">void</span> <span style="color:#009900">onScrolled</span>(RecyclerView recyclerView, <span style="color:#000088">int</span> dx, <span style="color:#000088">int</span> dy) {
        <span style="color:#000088">super</span>.onScrolled(recyclerView, dx, dy);

    }
});
</code></span>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

1.2 滑动监听回调方法说明

1.3 判断RecyclerView的滑动方向

  • onScrollStateChanged(RecyclerView recyclerView, int newState)这个方法在RecyclerView的滑动状态改变时会调用

对应的参数 newState 有三种状态 ,官方这样描述

<span style="color:#000000"><code>    <span style="color:#880000">/**
     * The RecyclerView is not currently scrolling.
     *<span style="color:#4f4f4f"> @see</span> #getScrollState()
     */</span>
    <span style="color:#000088">public</span> <span style="color:#000088">static</span> <span style="color:#000088">final</span> <span style="color:#000088">int</span> SCROLL_STATE_IDLE = <span style="color:#006666">0</span>;

    <span style="color:#880000">/**
     * The RecyclerView is currently being dragged by outside input such as user touch input.
     *<span style="color:#4f4f4f"> @see</span> #getScrollState()
     */</span>
    <span style="color:#000088">public</span> <span style="color:#000088">static</span> <span style="color:#000088">final</span> <span style="color:#000088">int</span> SCROLL_STATE_DRAGGING = <span style="color:#006666">1</span>;

    <span style="color:#880000">/**
     * The RecyclerView is currently animating to a final position while not under
     * outside control.
     *<span style="color:#4f4f4f"> @see</span> #getScrollState()
     */</span>
    <span style="color:#000088">public</span> <span style="color:#000088">static</span> <span style="color:#000088">final</span> <span style="color:#000088">int</span> SCROLL_STATE_SETTLING = <span style="color:#006666">2</span>;
</code></span>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

也就是说,newState=0时,RecyclerView在停止状态中 
newState=1和newState=2时,RecyclerView在滑动状态中 
不同的是,当由0—>1 ,2 时,RecyclerView由静止状态下变为滑动状态,然后1–0 滑动状态变为静止(调用方法 mHomeDateRecyclerView.smoothScrollToPosition(currentPostion); 等这一类方法所触发) , 2–>0 滑动状态变为静止状态(左右滑动RecyclerView 动态的慢慢结束)

  • onScrolled(RecyclerView recyclerView, int dx, int dy ) 这个方法在RecyclerView开始滑动时实时回调

参数dx dy分别是RecyclerView在滑动过程中,在x轴方向(横向滑动)与Y轴方向(纵向滑动)的偏移量 
dx>0 向右滑动 
dx<0 向左滑动

dy<0 向上滑动 
dy>0 向下滑动

 


2 RecyclerView 的滑动滑动距离获取

可以在RecyclerView的滑动监听中调用此方法,以不断的来获取RecyclerView的滑动距离

<span style="color:#000000"><code class="language-java"><span style="color:#880000">//mMTrainLinearLayoutManager 是 Recyclerview对应的布局管理者</span>
<span style="color:#000088">if</span> (mMTrainLinearLayoutManager != <span style="color:#000088">null</span>) {
       <span style="color:#880000">//获取RecyclerView当前顶部显示的第一个条目对应的索引    </span>
       <span style="color:#000088">int</span> position = mMTrainLinearLayoutManager.findFirstVisibleItemPosition();
       <span style="color:#880000">//根据索引来获取对应的itemView </span>
       View firstVisiableChildView = mMTrainLinearLayoutManager.findViewByPosition(position);
       <span style="color:#880000">//获取当前显示条目的高度</span>
       <span style="color:#000088">int</span> itemHeight = firstVisiableChildView.getHeight();
       <span style="color:#880000">//获取当前Recyclerview 偏移量</span>
       <span style="color:#000088">int</span> flag = (position) * itemHeight - firstVisiableChildView.getTop();

       LogUtils.d(<span style="color:#009900">"scroll "</span> + dx + <span style="color:#009900">"  "</span> + dy + <span style="color:#009900">" flag "</span> + flag);
   }</code></span>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值