美文网首页Android代码片段Android技术知识
一行代码搞定使用LinearLayoutManager一键返回顶

一行代码搞定使用LinearLayoutManager一键返回顶

作者: 八怪不姓丑 | 来源:发表于2017-02-14 16:49 被阅读465次

    之前在学习RecyclerView的时候,建立了一个可以滑动的View列表,但是当滑动距离过长的时候,需要手动返回到顶部,于是加了一个一键返回顶部的按钮。

    效果图

    要实现这种效果,有两点需要实现:

    1、控制LanyoutManager滑动距离,根据滑动状态(距离)改变去设置隐藏或者显示。
    2、设置top的点击事件,点击回到顶部。

    很遗憾LayoutManager只提供给了我们获取第一个可见item的高度的方法,而这里我们需要获取的是从开始到现在滑动的总距离,所以不得不动手去自己写,网上也有很多方法,试了一通还是这个比较好用。

    建议如果对RecyclerView还不是太熟悉的可以试试他的一些获取高度的方法,
    getChildAt()getHeight(),来看一下效果,
    关于index,可以通过findFirstVisibleItemPosition();获取,
    刚开始很天真的以为官方会提供有方法,然而进方法源码去看并没有,如果各位同行有更好的方法欢迎留言。

      public int getScollYDistance() {
            int position = layoutManager.findFirstVisibleItemPosition();
            View firstVisiableChildView = layoutManager.findViewByPosition(position);
            int firstVisiableChildViewTop = firstVisiableChildView.getTop();
            int itemHeight = firstVisiableChildView.getHeight();
            //可见的item的index*item高度-最顶端位置
            return (position) * itemHeight - firstVisiableChildViewTop;
        }
    

    获取高度之后
    我们需要获取高度,设置效果
    可以diy各种效果,常见的效果比如支付宝开始滑动的时候,title会渐变最后慢慢隐藏换成其他功能。都在这个方法里实现

    如果只需要我们做返回顶部的效果,那么直接在这里设置距离就行了,这个距离就是滑动的总距离,当滑动距离超过400的时候设置按钮可见,小于400的时候隐藏掉。

        public void selectItem() {
                 
            //弹出top返回顶部按钮
            if (getScollYDistance()>=400){
                backTop.setVisibility(View.VISIBLE);
            }else {
                backTop.setVisibility(View.GONE);
            }
    
        }
    

    当然这只是最简单的样式,要复杂的一点的话可以这样:
    在滑动中改变效果,或者设置渐变效果

    if (getScollYDistance() <= 0) {          
                float scale = (float) getScollYDistance() / 400;
                float alpha = (255 * scale);
                // 只是layout背景透明(仿知乎滑动效果)
                tvTitle.setBackgroundColor(Color.argb((int) alpha, 254, 184, 6));
            } else {
    //            tvTitle.setBackgroundColor(Color.argb((int) 0, 254, 184, 6));
                tvTitle.setVisibility(View.GONE);
            }
    

    等等,自己想要什么样的效果,在这里面设置就行。

    然后只需要我们在滑动事件中添加效果。

                @Override
                public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
                    super.onScrolled(recyclerView, dx, dy);
    
                    selectItem();
    }
    

    最后不要忘了设置返回按钮的监听事件

    只一行代码scrollToPosition(0);每次点击让其返回初始位置即可完成一键返回到顶部的操作。

            backTop.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    recyclerView.scrollToPosition(0);
                }
            });
    

    附上xml:

     <RelativeLayout
         android:id="@+id/view_relat"
         android:layout_width="match_parent"
         android:layout_height="match_parent">
    <android.support.v4.widget.SwipeRefreshLayout
        android:id="@+id/swipeRefreshLayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    <android.support.v7.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:dividerHeight="2dp"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>
    </android.support.v4.widget.SwipeRefreshLayout>
      <RelativeLayout
          android:layout_width="80dp"
          android:layout_height="80dp"
          android:layout_alignParentBottom="true"
          android:layout_alignParentEnd="true">
        <ImageView
            android:id="@+id/back_top"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/back_top_icon"
            android:visibility="gone"/>
      </RelativeLayout>
     </RelativeLayout>
    

    有兴趣的话可以去看github的源码
    https://github.com/wapchief/android-CollectionDemo
    欢迎一起交流,互相学习。

    相关文章

      网友评论

        本文标题:一行代码搞定使用LinearLayoutManager一键返回顶

        本文链接:https://www.haomeiwen.com/subject/ymzjittx.html