android中LinearLayoutManager一键返回顶部示例
之前在学习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>
源码下载:android-collectiondemo_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。