欢迎来到代码驿站!

Android代码

当前位置:首页 > 移动开发 > Android代码

android中LinearLayoutManager一键返回顶部示例

时间:2021-09-24 10:57:20|栏目:Android代码|点击:

之前在学习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

上一篇:Android 简单跳转页面工具的实例详解

栏    目:Android代码

下一篇:Android开发中调用系统相册上传图片到服务器OPPO等部分手机上出现短暂的显示桌面问题的解决方法

本文标题:android中LinearLayoutManager一键返回顶部示例

本文地址:http://www.codeinn.net/misctech/176974.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有