欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

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

程序员文章站 2022-07-11 23:18:28
本文要实现内容移动时,标题栏自动缩放/放大的效果,效果如下: 控件介绍 这次需要用到得新控件比较多,主要有以下几个: coordinatorlayout 组...

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

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

控件介绍

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

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的使用说明可以参考探索新的android material design支持库

代码实现

//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

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