CollapsingToolbarLayout 主要用於實現一個可摺疊的標題欄,通常做爲 AppBarLayout 的子 View 來使用,下面總結一下 CollapsingToolbarLayout 的使用。android
Material Design 系列文章:segmentfault
//是否顯示標題 app:titleEnabled="true" //標題內容 app:title="CollapsingToolbarLayout" //擴展後Title的位置 app:expandedTitleGravity="left|bottom" //收縮後Title的位置 app:collapsedTitleGravity="left" //CollapsingToolbarLayout收縮後Toolbar的背景顏色 app:contentScrim ="@color/colorPrimary" //CollapsingToolbarLayout收縮時顏色變化的持續時間 app:scrimAnimationDuration="1200" //顏色從可見高度的什麼位置開始變化 app:scrimVisibleHeightTrigger="150dp" //狀態顏色變化(Android 5.0) app:statusBarScrim="@color/colorAccent" //設置滑動組件與手勢之間的關係 app:layout_scrollFlags="scroll|exitUntilCollapsed"
對於 Title 當摺疊佈局徹底可見時 Title 變大,可摺疊佈局隨着向上滑動可見範圍變小 Title 也變小,能夠經過以下方式設置 Title 的顏色,具體以下:微信
//設置標題 ctlCollapsingLayout.setTitle("CollapsingToolbarLayout"); //設置CollapsingToolbarLayout擴展時的顏色 ctlCollapsingLayout.setExpandedTitleColor(Color.parseColor("#ffffff")); //設置CollapsingToolbarLayout收縮時的顏色 ctlCollapsingLayout.setCollapsedTitleTextColor(Color.parseColor("#46eada"));
這個 Title 的顏色漸變過程由 CollapsingToolbarLayout 完成,固然其餘部分屬性也能夠在代碼中設置。app
單獨在說一下兩個重要屬性,能夠做爲一個標誌位來記:佈局
layout_scrollFlags:通常使用 CoordinatorLayout、AppBarLayout等這些組件構成的界面,通常都有一個滾動視圖,如 NestedScrollView,滾動視圖通常設置了系統默認的 Behavior,具體以下:學習
//設置layout_behavior屬性 <android.support.v4.widget.NestedScrollView android:layout_width="match_parent" android:layout_height="match_parent" app:layout_behavior="@string/appbar_scrolling_view_behavior"> ... </android.support.v4.widget.NestedScrollView>
要隨着滾動視圖移動的組件,如 ToolBar、CollapsingToolbarLayout 等須要設置 layout_scrollFlags 屬性來指定不一樣的動做,關於 layout_scrollFlags 值的具體含義請參考以前的一篇文章: Material Design 組件之 AppBarLayout 。spa
layout_collapseMode:layout_collapseMode 有兩個值能夠選擇,若是設置了 pin 的 View 會隨着頁面向上滾動固定到頂部,若是設置了 parallax 的 View 會隨着頁面的滾動而滾動,此時能夠結合另外一個屬性 layout_collapseParallaxMultiplier 造成視差滾動的效果。.net
CollapsingToolbarLayout 的介紹就到此爲止,沒有案例固然是不能夠,下面是一個簡單的使用案列,佈局以下:code
<?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" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.manu.materialdesignsamples.samples.SampleCollapsingToolbarLayoutActivity"> <android.support.design.widget.AppBarLayout android:layout_width="match_parent" android:layout_height="200dp"> <android.support.design.widget.CollapsingToolbarLayout android:id="@+id/ctlCollapsingLayout" android:layout_width="match_parent" android:layout_height="match_parent" app:titleEnabled="true" app:title="CollapsingToolbarLayout" app:expandedTitleGravity="left|bottom" app:collapsedTitleGravity="left" app:contentScrim ="@color/colorPrimary" app:scrimAnimationDuration="1200" app:scrimVisibleHeightTrigger="150dp" app:statusBarScrim="@color/colorAccent" app:layout_scrollFlags="scroll|exitUntilCollapsed"> <ImageView android:layout_width="match_parent" android:layout_height="wrap_content" app:layout_collapseMode="parallax" app:layout_collapseParallaxMultiplier="0.6" android:background="@drawable/ic_collapsing_title"/> <android.support.v7.widget.Toolbar android:id="@+id/toolbar" android:layout_width="match_parent" android:layout_height="70dp" android:minHeight="?attr/actionBarSize" app:layout_collapseMode="pin"> </android.support.v7.widget.Toolbar> </android.support.design.widget.CollapsingToolbarLayout> </android.support.design.widget.AppBarLayout> <android.support.v4.widget.NestedScrollView android:layout_width="match_parent" android:layout_height="match_parent" app:layout_behavior="@string/appbar_scrolling_view_behavior"> <android.support.v7.widget.RecyclerView android:id="@+id/rvCollapsing" android:layout_width="match_parent" android:layout_height="match_parent"/> </android.support.v4.widget.NestedScrollView> </android.support.design.widget.CoordinatorLayout>
下面是顯示效果,具體以下:xml
能夠選擇關注微信公衆號:jzman-blog 獲取最新更新,一塊兒交流學習!