LinearLayout的子類
AppBarLayout要點:
-
功能:讓子View(AppBar)可以選擇他們自己的滾動行為。
-
注意:需要依賴CoordinatorLayout作為父容器,同時也要求一個具有可以獨立滾動的兄弟節點(或兄弟節點的子view可以滾動)才能發揮其功能。
<?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" tools:context="com.arenas.appbarlayouttest.MainActivity" android:layout_width="match_parent" android:layout_height="match_parent"> <!-- AppBarLayout,作為CoordinatorLayout的子類 --> <android.support.design.widget.AppBarLayout android:layout_width="match_parent" android:fitsSystemWindows="true" android:layout_height="wrap_content" > <android.support.v7.widget.Toolbar android:id="@+id/toolbar" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" android:background="?attr/colorPrimary" app:layout_scrollFlags="scroll|enterAlways" /> </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"> <!-- Your scrolling content --> <TextView android:layout_width="match_parent" android:layout_margin="20dp" android:text="text" android:layout_height="wrap_content"/> </android.support.v4.widget.NestedScrollView> </android.support.design.widget.CoordinatorLayout>
然后再Activity中設置好toolbar即可運行程序,可以看到效果……
注意:
兄弟節點的app:layout_behavior="@string/appbar_scrolling_view_behavior"屬性很重要;
AppBarLayout子view的app:layout_scrollFlags屬性很重要,其值有三個:
scroll: 所有想滾動出屏幕的view都需要設置這個flag(所以,這里的toolbar設置了),沒有設置這個flag的view將被固定在屏幕頂部。
enterAlways: 這個flag讓任意向下的滾動都會導致該view變為可見(向下滾動,toolbar又出現),啟用”快速返回”模式。
enterAlwaysCollapsed: 當你的視圖已經設置minHeight屬性又使用此標志時,你的視圖只會在最小高度處進入,只有當滾動視圖到達頂部時才擴大到完整高度。
exitUntilCollapsed: 在滾動過程中,只有當視圖折疊到最小高度的時候,它才退出屏幕。
注意AppBarLayout的兄弟節點(或兄弟節點的子view)一定要是可以滾動的View/ViewGroup,如:NestedScrollView,RecycleView;(據說ListView不行,木有測試了)
那些使用Scroll flag的視圖必須在其他沒有使用Scroll flag的視圖之前聲明。這樣才能確保所有的視圖從頂部撤離,剩下的元素固定在前面(譯者注:剩下的元素壓在其他元素的上面)。
參考文章:http://blog.csdn.net/ydxlt/article/details/50932432
