全网整合营销服务商

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

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

Android 使用CoordinatorLayout实现滚动标题栏效果的实例

在Material Design里,CoordinatorLayout通常用来作为顶层视图,来协调处理各个子View之间的动作,从而实现各种动画效果,如Snackbar与FloatingActionButton的配合显示效果,就是以CoordinatorLayout作为根布局来实现的

CoordinatorLayout提供Behaviors接口,子View通过实现Behaviors接口来协调和其它View之间的显示效果,可以这么理解:

CoordinatorLayout让其子View之间互相知道彼此的存在,任意一个子View的状态变化会通过Behaviors通知其它子View,CoordinatorLayout就像一个桥梁,连接不同的View,并使用Behavior处理各个子View之间的通信

效果一:

想实现这样的效果挺简单的,主要是在xml布局文件中进行设置

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  xmlns:app="http://schemas.android.com/apk/res-auto">

  <!--包裹头部View实现滑动效果-->
  <android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:theme="@style/ThemeOverlay.AppCompat">

    <!--标题栏-->
    <android.support.v7.widget.Toolbar
      android:id="@+id/tb_toolbar"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      app:navigationIcon="@android:drawable/ic_dialog_email"
      app:title="Title"
      app:layout_scrollFlags="scroll" />

    <!--Tab导航栏-->
    <android.support.design.widget.TabLayout
      android:id="@+id/tab_layout"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      app:tabMode="fixed"
      app:layout_scrollFlags="scroll|enterAlways"/>

  </android.support.design.widget.AppBarLayout>

  <android.support.v4.view.ViewPager
    android:id="@+id/vp_tab_pager"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

</android.support.design.widget.CoordinatorLayout>

首先给被AppBarLayout包裹的View添加app:layout_scrollFlags属性,并设置相应的值

• scroll:让该View可以滚动出屏幕

• enterAlways:不需要滚动到顶部,只要有向上滚动的事件就显示该View

• enterAlwaysCollapsed:定义该View何时进入,如果你定义了一个最小高度minHeight,同时enterAlways也定义了,那么该View将会在到达这个最小高度的时候开始慢慢显示,直到滚动组件滚动到顶部时再完全展开

• exitUntilCollapsed:定义该View何时退出,如果你定义了一个最小高度minHeight,那么这个View将在滚动到达这个最小高度时消失

如果不设置layout_scrollFlags属性,那么该View就会固定在屏幕上

enterAlwaysCollapsed和exitUntilCollapsed属性主要是在搭配CollapsingToolbarLayout时使用的

注意:布局的时候,AppBarLayout里面滚动的View要放在固定的View上面

然后在CoordinatorLayout布局里放一个可以滚动的View(不支持ListView),这里使用ViewPager里放置一个RecylerView,为该ViewPager设置app:layout_behavior属性,这里可直接使用Android自带的值

app:layout_behavior=”@string/appbar_scrolling_view_behavior”

设置该值的作用相当于告诉CoordinatorLayout,此View是一个滚动控件,如果该View滚动了,那么设置了layout_scrollFlags属性的控件就可以响应滚动事件了

想实现效果一,总结

使用CoordinatorLayout作为根布局

使用AppBarLayout包裹头部View,并给需要滚动的View设置app:layout_scrollFlags属性

给滑动组件设置app:layout_behavior属性

效果二:

想实现这个效果,需要使用到CollapsingToolbarLayout布局,我们在效果一的基础上更改布局代码

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  android:layout_width="match_parent"
  android:layout_height="match_parent">

  <android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="300dp"
    android:fitsSystemWindows="true"
    android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

    <android.support.design.widget.CollapsingToolbarLayout
      android:id="@+id/collapsing_toolbar"
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      app:contentScrim="?attr/colorPrimary"
      app:expandedTitleMarginEnd="88dp"
      app:expandedTitleMarginStart="66dp"
      app:layout_scrollFlags="scroll|exitUntilCollapsed">

      <!--拉开后显示的背景图片-->
      <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scaleType="centerCrop"
        android:src="@drawable/bg_image"
        app:layout_collapseMode="pin"/>

      <!--标题栏-->
      <android.support.v7.widget.Toolbar
        android:id="@+id/tb_toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        app:layout_collapseMode="pin"
        app:navigationIcon="@android:drawable/ic_dialog_email"
        app:title="Title"/>

    </android.support.design.widget.CollapsingToolbarLayout>

  </android.support.design.widget.AppBarLayout>

  <android.support.v7.widget.RecyclerView
    android:id="@+id/rv_data"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

</android.support.design.widget.CoordinatorLayout>

一些属性的作用

• title:设置Toolbar的标题,注意:如果在CollapsingToolbarLayout中指定了title属性,那么Toolbar中的title属性将会变得无效

• expandedTitleMarginStart:设置下拉伸缩完成后,ToolBar标题文字左边的margin距离

• expandedTitleMarginEnd:设置下拉伸缩完成后,Toolbar标题文字右边的margin距离

• contentScrim:设置Toolbar折叠到顶部后的背景

• layout_collapseMode:折叠效果,有两个值,pin代表从底部拉出,parallax代表从中间展开

看文字可能不太理解collapseMode的显示效果,两个值的具体显示效果如下:

pin:

parallax:

想实现效果二,总结

首先我们设置一个固定的高度给AppBarLayout

然后给AppBarLayout的子View包裹了一层CollapsingToolbarLayout,并设置CollapsingToolbarLayout的滚动属性为scroll|exitUntilCollapsed

最后再为CollapsingToolbarLayout里的子View设置layout_collapseMode属性,指定其展示效果

以上这篇Android 使用CoordinatorLayout实现滚动标题栏效果的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# coordinatorlayout实现滚动标题栏  # Android中自定义标题栏样式的两种方法  # 3种Android隐藏顶部状态栏及标题栏的方法  # Android自定义状态栏颜色与应用标题栏颜色一致  # Android 顶部标题栏随滑动时的渐变隐藏和渐变显示效果  # Android中去掉标题栏的几种方法(三种)  # Android 全屏无标题栏的三种实现方法  # Android中隐藏标题栏和状态栏的方法  # Android ScrollView滑动实现仿QQ空间标题栏渐变  # Android中隐藏状态栏和标题栏的方法汇总(隐藏状态栏、标题栏的五种方法)  # Android实现可折叠式标题栏  # 显示效果  # 如果你  # 是在  # 标题栏  # 给大家  # 拉出  # 是一个  # 就会  # 完成后  # 放在  # 就像  # 将会  # 将在  # 不太  # 不需要  # 基础上  # 会在  # 希望能  # 不支持  # 这篇 


相关文章: 如何快速搭建虚拟主机网站?新手必看指南  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  如何通过万网虚拟主机快速搭建网站?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  建站主机选虚拟主机还是云服务器更好?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  网站设计制作公司地址,网站建设比较好的公司都有哪些?  简易网站制作视频教程,使用记事本编写一个简单的网页html文件?  如何在IIS中新建站点并配置端口与物理路径?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  如何在IIS7上新建站点并设置安全权限?  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  如何制作一个表白网站视频,关于勇敢表白的小标题?  如何通过西部建站助手安装IIS服务器?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  如何用PHP工具快速搭建高效网站?  深圳 网站制作,深圳招聘网站哪个比较好一点啊?  建站之星如何配置系统实现高效建站?  ppt制作免费网站有哪些,ppt模板免费下载网站?  建站之星后台搭建步骤解析:模板选择与产品管理实操指南  5种Android数据存储方式汇总  如何选择域名并搭建高效网站?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  活动邀请函制作网站有哪些,活动邀请函文案?  Java解压缩zip - 解压缩多个文件或文件夹实例  如何通过网站建站时间优化SEO与用户体验?  常州自助建站费用包含哪些项目?  ,柠檬视频怎样兑换vip?  如何在阿里云ECS服务器部署织梦CMS网站?  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  如何通过VPS搭建网站快速盈利?  建站之星展会模板:智能建站与自助搭建高效解决方案  制作网站公司那家好,网络公司是做什么的?  建站中国官网:模板定制+SEO优化+建站流程一站式指南  建站之星后台密码如何安全设置与找回?  如何在香港服务器上快速搭建免备案网站?  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  东莞专业制作网站的公司,东莞大学生网的网址是什么?  网站制作价目表怎么做,珍爱网婚介费用多少?  制作证书网站有哪些,全国城建培训中心证书查询官网?  建站之星免费版是否永久可用?  如何通过VPS建站实现广告与增值服务盈利?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  如何零基础在云服务器搭建WordPress站点?  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  如何在Golang中指定模块版本_使用go.mod控制版本号  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  如何在宝塔面板创建新站点?  如何快速搭建高效WAP手机网站吸引移动用户? 

您的项目需求

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