android中LinearLayoutManager一键返回顶部示例

作者:八怪不姓丑 时间:2022-02-23 19:19:26 

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

效果图

android中LinearLayoutManager一键返回顶部示例

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

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

来源:http://www.jianshu.com/p/e9778888d1c3

标签:android,LinearLayout
0
投稿

猜你喜欢

  • org.slf4j.Logger中info()方法的使用详解

    2021-05-31 20:10:36
  • Android中LinearLayout布局的常用属性总结

    2023-11-23 17:09:37
  • 通过WIFI(不用数据线)连接Android手机调试

    2023-01-05 18:20:45
  • Spring Bean后处理器详细介绍

    2021-06-27 07:29:06
  • 教你5分钟轻松搞定内存字节对齐

    2022-05-03 08:35:10
  • C++语言实现线性表之链表实例

    2023-06-20 22:21:20
  • java8 集合 多字段 分组 统计个数代码

    2022-12-07 21:03:34
  • Spring Boot整合Redis的完整步骤

    2023-06-03 03:21:56
  • C#无损高质量压缩图片实现代码

    2021-10-18 06:23:29
  • maven资源过滤打包后文件变大的处理方法

    2023-10-05 21:38:24
  • C#实现带消息数的App图标

    2022-03-08 11:30:52
  • Spring注解与P/C命名空间超详细解析

    2022-08-04 19:42:34
  • C#后端接收form-data,创建实体类教程

    2023-08-23 21:07:57
  • Spring Security权限管理实现接口动态权限控制

    2022-07-03 12:25:53
  • C#实现泛型List分组输出元素的方法

    2022-03-10 07:33:15
  • Android编程实现ListView滚动提示等待框功能示例

    2022-11-15 13:50:15
  • C#中out保留字用法实例分析

    2021-07-28 18:44:54
  • C++中auto_ptr智能指针的用法详解

    2023-05-21 02:14:05
  • Javaweb会话跟踪技术Cookie和Session的具体使用

    2022-06-24 21:16:33
  • Android studio设置文件头定制代码注释的方法

    2021-07-23 16:52:41
  • asp之家 软件编程 m.aspxhome.com