一行代码搞定使用LinearLayoutManager一键返回顶部
2017-02-14 17:21
357 查看
之前在学习RecyclerView的时候,建立了一个可以滑动的View列表,但是当滑动距离过长的时候,需要手动返回到顶部,于是加了一个一键返回顶部的按钮。
要实现这种效果,有两点需要实现:
1、控制LanyoutManager滑动距离,根据滑动状态(距离)改变去设置隐藏或者显示。
2、设置top的点击事件,点击回到顶部。
很遗憾LayoutManager只提供给了我们获取第一个可见item的高度的方法,而这里我们需要获取的是从开始到现在滑动的总距离,所以不得不动手去自己写,网上也有很多方法,试了一通还是这个比较好用。
建议如果对RecyclerView还不是太熟悉的可以试试他的一些获取高度的方法,
像
关于index,可以通过
刚开始很天真的以为官方会提供有方法,然而进方法源码去看并没有,如果各位同行有更好的方法欢迎留言。
获取高度之后
我们需要获取高度,设置效果
可以diy各种效果,常见的效果比如支付宝开始滑动的时候,title会渐变最后慢慢隐藏换成其他功能。都在这个方法里实现
如果只需要我们做返回顶部的效果,那么直接在这里设置距离就行了,这个距离就是滑动的总距离,当滑动距离超过400的时候设置按钮可见,小于400的时候隐藏掉。
当然这只是最简单的样式,要复杂的一点的话可以这样:
在滑动中改变效果,或者设置渐变效果
等等,自己想要什么样的效果,在这里面设置就行。
然后只需要我们在滑动事件中添加效果。
最后不要忘了设置返回按钮的监听事件
只一行代码
附上xml:
有兴趣的话可以去看github的源码
https://github.com/wapchief/android-CollectionDemo
欢迎一起交流,互相学习。
要实现这种效果,有两点需要实现:
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
欢迎一起交流,互相学习。
相关文章推荐
- 生活中的“返回顶部”原来代码这么简单,一个锚点链接(超链接{a}里的一种)就搞定!
- 一行代码不用敲,15分钟轻松搞定GIS开发,GISer福音,教你如何从下载到使用webappbuilder创建第一个应用程序(不用申请有使用期限的企业账号哦!)
- 一行代码不用敲,15分钟轻松搞定GIS开发,GISer福音,教你如何从下载到使用webappbuilder创建第一个应用程
- 一行代码搞定 R 语言模型输出!(使用 stargazer 包)
- 无需一行代码就能搞定机器学习的开源神器——手把手教你配置使用
- Oracle存储过程中执行查询返回的结果集,并使用java代码调用【转】
- 一行代码让你基于IE6/7开发的网页能够在IE8中正常使用
- 只需一行代码实现增删查改,微软已经让我们很简单。谈AccessDataSource的使用。
- 使用SAFEARRAY返回的代码
- 一行代码搞定省市区三级联动(推荐一个JS封装类)
- 在看官方的例子时候由一个grid实例,在每一行之前有个加号,展开可以显示内容,在实际应用中还是非常有用的,照搬例子的代码,发现老是提示对象不存在,查阅资料后发现是没有加载插件,这里和大家分享下Ext.grid.RowExpander插件的使用,
- 这些问题你可以用一行代码可以搞定吗?
- 迅速返回页面顶部代码
- [JavaScript]只需一行代码,轻松搞定快捷留言-V2升级版
- C# 一行代码 搞定漂亮UI 不影响任何原有程序代码
- 学习Python列表内涵:一行代码搞定双倍超立方数计算
- JTable 的TableModel (使用TMF框架只用一行代码)
- 使用MFC搜索当前目录下所存在的某种文件,将文件名(路径等)添加到下拉框中,返回文件个数,部分关键代码。。
- 一行代码搞定你的QueryString!(原创)
- 使用JAVA发送HTTP请求(Http Request),返回HTTP响应(Http Response)内容,代码程序例子及原理说明