全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# android  # 返回顶部  # 一键回到顶部  # 返回顶部按钮  # Android LinearLayout实现自动换行效果  # Android LinearLayout实现自动换行  # Android自定义LinearLayout布局显示不完整的解决方法  # Android使用LinearLayout设置边框  # Android编程使用LinearLayout和PullRefreshView实现上下翻页功能的方法  # Android中的LinearLayout布局  # Android基础之获取LinearLayout的宽高  # Android超详细讲解组件LinearLayout的使用  # 只需要  # 一键  # 在这里  # 也有  # 都在  # 第一个  # 在这  # 是从  # 就行  # 可以通过  # 给了  # 去看  # 弹出  # 这只  # 刚开始  # 好用  # 只提供  # 最简单  # 试了  # 支付宝 


相关文章: 如何在阿里云域名上完成建站全流程?  建站主机助手选型指南:2025年热门推荐与高效部署技巧  如何解决ASP生成WAP建站中文乱码问题?  网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?  韩国服务器如何优化跨境访问实现高效连接?  html制作网站的步骤有哪些,iapp如何添加网页?  微信推文制作网站有哪些,怎么做微信推文,急?  高防服务器租用首荐平台,企业级优惠套餐快速部署  制作农业网站的软件,比较好的农业网站推荐一下?  建站之星2.7模板快速切换与批量管理功能操作指南  如何快速生成可下载的建站源码工具?  如何选择高效响应式自助建站源码系统?  建站之星ASP如何实现CMS高效搭建与安全管理?  电商平台网站制作流程,电商网站如何制作?  北京建设网站制作公司,北京古代建筑博物馆预约官网?  ui设计制作网站有哪些,手机UI设计网址吗?  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  湖北网站制作公司有哪些,湖北清能集团官网?  常州企业网站制作公司,全国继续教育网怎么登录?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  香港服务器租用每月最低只需15元?  如何配置支付宝与微信支付功能?  简易网站制作视频教程,使用记事本编写一个简单的网页html文件?  C#如何在一个XML文件中查找并替换文本内容  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  如何在局域网内绑定自建网站域名?  如何选择高性价比服务器搭建个人网站?  如何在阿里云服务器自主搭建网站?  如何在景安云服务器上绑定域名并配置虚拟主机?  如何自定义建站之星网站的导航菜单样式?  百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?  Android自定义listview布局实现上拉加载下拉刷新功能  宁波免费建站如何选择可靠模板与平台?  详解jQuery停止动画——stop()方法的使用  建站主机选购指南与交易推荐:核心配置解析  公司网站设计制作厂家,怎么创建自己的一个网站?  建站之星如何快速更换网站模板?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  网站app免费制作软件,能免费看各大网站视频的手机app?  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  电商网站制作价格怎么算,网上拍卖流程以及规则?  如何高效配置香港服务器实现快速建站?  如何在云主机上快速搭建多站点网站?  如何在IIS7中新建站点?详细步骤解析  如何设计高效校园网站?  如何在Golang中使用encoding/gob序列化对象_存储和传输数据  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。