Material Design 组件之 CollapsingToolbarLayout
CollapsingToolbarLayout 主要用于實(shí)現(xiàn)一個(gè)可折疊的標(biāo)題欄,一般作為 AppBarLayout 的子 View 來(lái)使用,下面總結(jié)一下 CollapsingToolbarLayout 的使用。
Material Design 系列文章:
- Material Design 組件之 FloatingActionButton
- Material Design 組件之 AppBarLayout
常用屬性
//是否顯示標(biāo)題 app:titleEnabled="true" //標(biāo)題內(nèi)容 app:title="CollapsingToolbarLayout" //擴(kuò)展后Title的位置 app:expandedTitleGravity="left|bottom" //收縮后Title的位置 app:collapsedTitleGravity="left" //CollapsingToolbarLayout收縮后Toolbar的背景顏色 app:contentScrim ="@color/colorPrimary" //CollapsingToolbarLayout收縮時(shí)顏色變化的持續(xù)時(shí)間 app:scrimAnimationDuration="1200" //顏色從可見(jiàn)高度的什么位置開(kāi)始變化 app:scrimVisibleHeightTrigger="150dp" //狀態(tài)顏色變化(Android 5.0) app:statusBarScrim="@color/colorAccent" //設(shè)置滑動(dòng)組件與手勢(shì)之間的關(guān)系 app:layout_scrollFlags="scroll|exitUntilCollapsed"對(duì)于 Title 當(dāng)折疊布局完全可見(jiàn)時(shí) Title 變大,可折疊布局隨著向上滑動(dòng)可見(jiàn)范圍變小 Title 也變小,可以通過(guò)如下方式設(shè)置 Title 的顏色,具體如下:
//設(shè)置標(biāo)題 ctlCollapsingLayout.setTitle("CollapsingToolbarLayout"); //設(shè)置CollapsingToolbarLayout擴(kuò)展時(shí)的顏色 ctlCollapsingLayout.setExpandedTitleColor(Color.parseColor("#ffffff")); //設(shè)置CollapsingToolbarLayout收縮時(shí)的顏色 ctlCollapsingLayout.setCollapsedTitleTextColor(Color.parseColor("#46eada"));這個(gè) Title 的顏色漸變過(guò)程由 CollapsingToolbarLayout 完成,當(dāng)然其他部分屬性也可以在代碼中設(shè)置。
兩個(gè)標(biāo)志位
單獨(dú)在說(shuō)一下兩個(gè)重要屬性,可以作為一個(gè)標(biāo)志位來(lái)記:
layout_scrollFlags:一般使用 CoordinatorLayout、AppBarLayout等這些組件構(gòu)成的界面,一般都有一個(gè)滾動(dòng)視圖,如 NestedScrollView,滾動(dòng)視圖一般設(shè)置了系統(tǒng)默認(rèn)的 Behavior,具體如下:
//設(shè)置layout_behavior屬性 <android.support.v4.widget.NestedScrollViewandroid:layout_width="match_parent"android:layout_height="match_parent"app:layout_behavior="@string/appbar_scrolling_view_behavior">... </android.support.v4.widget.NestedScrollView>要隨著滾動(dòng)視圖移動(dòng)的組件,如 ToolBar、CollapsingToolbarLayout 等需要設(shè)置 layout_scrollFlags 屬性來(lái)指定不同的動(dòng)作,關(guān)于 layout_scrollFlags 值的具體含義請(qǐng)參考之前的一篇文章: Material Design 組件之 AppBarLayout 。
layout_collapseMode:layout_collapseMode 有兩個(gè)值可以選擇,如果設(shè)置了 pin 的 View 會(huì)隨著頁(yè)面向上滾動(dòng)固定到頂部,如果設(shè)置了 parallax 的 View 會(huì)隨著頁(yè)面的滾動(dòng)而滾動(dòng),此時(shí)可以結(jié)合另一個(gè)屬性 layout_collapseParallaxMultiplier 形成視差滾動(dòng)的效果。
CollapsingToolbarLayout 的介紹就到此為止,沒(méi)有案例當(dāng)然是不可以,下面是一個(gè)簡(jiǎn)單的使用案列,布局如下:
<?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>顯示效果
下面是顯示效果,具體如下:
可以選擇關(guān)注微信公眾號(hào):jzman-blog 獲取最新更新,一起交流學(xué)習(xí)!
轉(zhuǎn)載于:https://www.cnblogs.com/jzmanu/p/10284775.html
總結(jié)
以上是生活随笔為你收集整理的Material Design 组件之 CollapsingToolbarLayout的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: The 'microsoft.jet.o
- 下一篇: [cpyhon源代码]dict对象原理学