当前位置: 移动技术网 > 移动技术>移动开发>Android > 学习使用Material Design控件(四)Android实现标题栏自动缩放、放大效果

学习使用Material Design控件(四)Android实现标题栏自动缩放、放大效果

2019年07月24日  | 移动技术网移动技术  | 我要评论

本文要实现内容移动时,标题栏自动缩放/放大的效果,效果如下:


控件介绍

这次需要用到得新控件比较多,主要有以下几个:

coordinatorlayout
组织它的子views之间协作的一个layout,它可以给子view切换提供动画效果。
appbarlayout
可以让包含在其中的控件响应被标记了scrollingviewbehavior的view的滚动事件
collapsingtoolbarlayout
可以控制包含在collapsingtoolbarlayout其中的控件,在响应collapse时是移除屏幕和固定在最上面
tablayout
结合viewpager,实现多个tab的切换的功能
nestedscrollview
与scrollview基本相同,不过包含在nestedscrollview中的控件移动时才能时appbarlayout缩放

layout布局

<?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:fitssystemwindows=“true”>

  <android.support.design.widget.appbarlayout
    android:layout_width=“match_parent”
    android:layout_height=“256dp”
    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”
      android:fitssystemwindows=“true”
      app:contentscrim=“?attr/colorprimary”
      app:expandedtitlemarginend=“64dp”
      app:expandedtitlemarginstart=“48dp”
      app:layout_scrollflags=“scroll|exituntilcollapsed”>

      <imageview
        android:id=“@+id/ivimage”
        android:layout_width=“match_parent”
        android:layout_height=“match_parent”
        android:fitssystemwindows=“true”
        android:scaletype=“centercrop”
        android:src=“@drawable/book1”
        app:layout_collapsemode=“parallax”
        app:layout_collapseparallaxmultiplier=“0.7” />

      <android.support.v7.widget.toolbar
        android:id=“@+id/toolbar”
        android:layout_width=“match_parent”
        android:layout_height=“?attr/actionbarsize”
        app:layout_collapsemode=“pin”
        app:popuptheme=“@style/themeoverlay.appcompat.light” />


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

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

  <linearlayout
    android:layout_width=“match_parent”
    android:layout_height=“match_parent”
    android:orientation=“vertical”
    app:layout_behavior=“@string/appbar_scrolling_view_behavior”>

    <android.support.design.widget.tablayout
      android:id=“@+id/sliding_tabs”
      android:layout_width=“match_parent”
      android:layout_height=“wrap_content”
      app:tabgravity=“fill”
      app:tabmode=“fixed” />

    <android.support.v4.view.viewpager
      android:id=“@+id/viewpager”
      android:layout_width=“match_parent”
      android:layout_height=“match_parent” />
  </linearlayout>
</android.support.design.widget.coordinatorlayout>

collapsingtoolbarlayout和tablayout的使用说明可以参考

代码实现

//toolbar
 toolbar toolbar = (toolbar) findviewbyid(r.id.toolbar);
 setsupportactionbar(toolbar);
 getsupportactionbar().setdisplayhomeasupenabled(true);
 toolbar.setnavigationonclicklistener(new view.onclicklistener() {
   @override
   public void onclick(view view) {
     onbackpressed();
   }
 });

//使用collapsingtoolbarlayout后,title需要设置到collapsingtoolbarlayout上
 collapsingtoolbarlayout collapsingtoolbar = (collapsingtoolbarlayout) findviewbyid(r.id.collapsing_toolbar);
 collapsingtoolbar.settitle("失控");

//设置viewpager
 mviewpager = (viewpager) findviewbyid(r.id.viewpager);
 setupviewpager(mviewpager);

//给tablayout增加tab, 并关联viewpager
 tablayout tablayout = (tablayout) findviewbyid(r.id.sliding_tabs);
 tablayout.addtab(tablayout.newtab().settext("内容简介"));
 tablayout.addtab(tablayout.newtab().settext("作者简介"));
 tablayout.addtab(tablayout.newtab().settext("目录"));
 tablayout.setupwithviewpager(mviewpager);

详细代码参见这里

项目源码已发布到github,material design新控件基本介绍完了,
下篇文章会结合豆瓣读书的api,整合一下这些控件,做一个demo。
源码地址:materialdesignexample

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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网