天天看點

Material Design元件之AppBarLayout

原文首發于微信公衆号:jzman-blog,歡迎關注交流!

AppBarLayout 是一個垂直方向的 LinearLayout,它實作了許多符合 Material Design 設計規範的狀态欄應該具有的功能,比如滾動手勢。

AppBarLayout 一般直接用作 CoordinatorLayout 的直接子對象,如果 AppBarLayout 在别的布局中使用,其大部分功能會失效,AppBarLayout 需要一個标示才能夠知道滾動視圖什麼時候滾動,這個标示過程是通過綁定 AppBarLayout.ScrollingViewBehavior 類完成的,這意味着應該将滾動視圖的行為設定為 AppBarLayout.ScrollingViewBehavior的一個執行個體,這裡設定包含完整類名的字元串資源,具體如下:

AppBarLayout 的子 View 應該設定一個可供滾動的 behavior,可以通過代碼和 xml 屬性設定,具體如下:

layout_scrollFlags 屬性主要是指定 AppBarLayout 子 View 當滑動手勢變化時,AppBarLayout 的子 View 執行什麼動作,layout_scrollFlags 屬性有 5 個值,分别是:

scroll

enterAlways

enterAlwaysCollapsed

exitUntilCollapsed

snap

在介紹這幾個屬性值之前,這些屬性值的效果将以下面布局效果為例,布局如下:

scroll: 當設定 layout_scrollFlags 的屬性為如下時:

此時,上滑時先隐藏 AppBarLayout,然後再開始滾動,下滑時直到滾動視圖的頂部出現 AppBarLayout 才開始顯示,效果如下:

enterAlways: enterAlways 必須配合 scroll 來使用,當設定 layout_scrollFlags 屬性為如下時:

此時,上滑時先隐藏AppBarLayout,然後再開始滾動,下滑時先顯示AppBarLayout,然後再開始滾動,效果如下:

enterAlwaysCollapsed: 使用 enterAlwaysCollapsed 屬性值時,必須配合 scroll 和 enterAlways 來使用,此外還需設定 AppBarLayout 的子 View (這裡是 Toolbar)一個最小高度 來提供 enterAlwaysCollapsed 的功能支援,當設定 layout_scrollFlags 的屬性為如下時:

此時,上滑時先隐藏AppBarLayout,然後再開始滾動,下滑時 AppBarLayout 先顯示子 View 最小高度,然後直到滾動視圖的頂部出現 AppBarLayout 全部顯示,效果如下:

exitUntilCollapsed: 使用 exitUntilCollapsed 屬性值時,必須配合 scroll 來使用,此外還需設定 AppBarLayout 的子 View (這裡是 Toolbar)一個最小高度 來提供 exitUntilCollapsed 的功能支援,當設定 layout_scrollFlags 的屬性為如下時:

此時,上滑時先隐藏 AppBarLayout 至最小高度,然後再開始滾動,下滑時直到滾動視圖的頂部出現 AppBarLayout 才開始顯示,效果如下:

snap: 使用 snap 屬性值時,必須配合 scroll 來使用,主要作用是在滾動結束時,如果伸縮的視圖隻是部分可見,那麼它将自動滾動到最近的邊緣,當設定 layout_scrollFlags 屬性為如下時:

此時,伸縮的視圖(這裡是 Toolbar)如果部分可見,那麼伸縮的視圖将自動滾動到最近的邊緣,即要麼隐藏、要麼顯示,效果如下:

關于 layout_scrollFlags 屬性就介紹完了,當然上面隻是為了說明屬性值的效果,還可以結合 CollapsingToolbarLayout 等其他 Material Design 實作酷炫的效果,上面是在布局檔案對 layout_scrollFlags 屬性的設定,順便說一下如何在代碼中設定 layout_scrollFlags 呢,具體如下:

AppBarLayout 的使用及其重要屬性已經介紹完了,實際開發中肯定要複雜的多,希望上面的内容能夠對你有所幫助。可以選擇關注個人微信公衆号:jzman-blog 擷取最新更新,一起交流學習!

Material Design元件之AppBarLayout