AppBarLayout一般用于賦予Toolbar(不限于Toolbar)滾動(dòng)行為,AppBarLayout是一個(gè)垂直的LinearLayout,實(shí)現(xiàn)了Material Design中app bar的scrolling gestures特性。AppBarLayout的子View應(yīng)該聲明想要具有的“滾動(dòng)行為”,這可以通過(guò)layout_scrollFlags屬性或是setScrollFlags()方法來(lái)指定。AppBarLayout只有作為CoordinatorLayout的直接子View時(shí)才能正常工作碍脏,為了讓AppBarLayout能夠知道何時(shí)滾動(dòng)其子View, 我們還應(yīng)該在CoordinatorLayout布局中提供一個(gè)可滾動(dòng)View稍算,如:RecyclerView
布局文件
<?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=".FloatingActivity">
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_scrollFlags="scroll"
app:title="標(biāo)題"></android.support.v7.widget.Toolbar>
</android.support.design.widget.AppBarLayout>
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview"
android:layout_width="match_parent"
android:layout_height="match_parent"></android.support.v7.widget.RecyclerView>
<android.support.design.widget.FloatingActionButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom|right"
android:src="@drawable/ic_add_24dp"
app:borderWidth="0dp"
app:layout_behavior=".FloatingBehavior" />
</android.support.design.widget.CoordinatorLayout>
layout_scrollFlags擁有6種模式
1.scroll--最基礎(chǔ)的模式典尾,并且設(shè)置其他模式必須|上它,否則不起效果
如果滾動(dòng)到頂部再往上滑動(dòng)的話(huà)糊探,則顯示Toolbar钾埂,只要往下滑動(dòng)河闰,則Toolbar消失
scroll.gif
2.enterAlways
如果往上滑動(dòng)的話(huà),則顯示Toolbar褥紫,只要往下滑動(dòng)姜性,則Toolbar消失
enterAlways.gif
3.enterAlwaysCollapsed
默認(rèn)Toolbar不遮擋滑動(dòng)控件,如果消失后再顯示髓考,則會(huì)遮擋部念,其他和scroll相同
enterAlwaysCollapsed.gif
4.exitUntilCollapsed--需要和minHeight一起配合使用,否則沒(méi)效果
Toolbar完全展開(kāi)時(shí)不遮擋滑動(dòng)控件氨菇,消失效果變?yōu)檎郫B成最小高度儡炼,其他和scroll相同
exitUntilCollapsed.gif
5.snap
Toolbar折疊的高度大于原高度的50%,則完全折疊查蓉,否則恢復(fù)展開(kāi)乌询,同樣的展開(kāi)的高度大于50%,則完全展開(kāi)豌研,否則恢復(fù)折疊
snap.gif
6.snapMargins
根據(jù)滑動(dòng)的距離折疊或者展開(kāi)Toolbar
snapMargins.gif
如果不想要遮擋滑動(dòng)控件的話(huà)妹田,我們需要為滑動(dòng)控件設(shè)置一個(gè)Behavior
app:layout_behavior="android.support.design.widget.AppBarLayout$ScrollingViewBehavior"