全网整合营销服务商

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

免费咨询热线: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的使用  # 只需要  # 一键  # 在这里  # 也有  # 都在  # 第一个  # 在这  # 是从  # 就行  # 可以通过  # 给了  # 去看  # 弹出  # 这只  # 刚开始  # 好用  # 只提供  # 最简单  # 试了  # 支付宝 


相关文章: 零基础网站服务器架设实战:轻量应用与域名解析配置指南  如何在Golang中使用replace替换模块_指定本地或远程路径  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  如何用wdcp快速搭建高效网站?  开源网站制作软件,开源网站什么意思?  购物网站制作公司有哪些,哪个购物网站比较好?  大型企业网站制作流程,做网站需要注册公司吗?  如何在阿里云虚拟服务器快速搭建网站?  建站之星后台密码如何安全设置与找回?  名字制作网站免费,所有小说网站的名字?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  b2c电商网站制作流程,b2c水平综合的电商平台?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  大连网站制作公司哪家好一点,大连买房网站哪个好?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  建站OpenVZ教程与优化策略:配置指南与性能提升  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  如何挑选高效建站主机与优质域名?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  网站制作说明怎么写,简述网页设计的流程并说明原因?  javascript中的try catch异常捕获机制用法分析  外贸公司网站制作哪家好,maersk船公司官网?  建站主机无法访问?如何排查域名与服务器问题  建站之星与建站宝盒如何选择最佳方案?  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  网站制作服务平台,有什么网站可以发布本地服务信息?  定制建站价位费用解析与套餐推荐全攻略  在线教育网站制作平台,山西立德教育官网?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  如何快速搭建二级域名独立网站?  建站之星北京办公室:智能建站系统与小程序生成方案解析  黑客如何通过漏洞一步步攻陷网站服务器?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  Python文件管理规范_工程实践说明【指导】  建站168自助建站系统:快速模板定制与SEO优化指南  宝塔面板创建网站无法访问?如何快速排查修复?  如何通过VPS建站无需域名直接访问?  早安海报制作网站推荐大全,企业早安海报怎么每天更换?  建站之星如何取消后台验证码生成?  建站之星安装路径如何正确选择及配置?  如何在橙子建站上传落地页?操作指南详解  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  如何快速搭建虚拟主机网站?新手必看指南  制作网站外包平台,自动化接单网站有哪些?  网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?  建站org新手必看:2024最新搭建流程与模板选择技巧  如何选择香港主机高效搭建外贸独立站?  建站之星后台管理系统如何操作?  如何选择靠谱的建站公司加盟品牌?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续? 

您的项目需求

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