控件介紹 (這里在理解之后需要修改 )
- AppBarLayout繼承自LinearLayout祠肥,布局方向為垂直方向贸辈。所以你可以把它當成垂直布局的LinearLayout來使用眨八。AppBarLayout是在LinearLayou上加了一些材料設(shè)計的概念,它可以讓你定制當某個可滾動View的滾動手勢發(fā)生變化時争舞,其內(nèi)部的子View實現(xiàn)何種動作但惶。
- 上面提到的某個可滾動View,可以理解為某個ScrollView漆枚。當這個ScrollView 發(fā)生滾動的時候 我們可以 定義appbarlayout里面的子view的動作
- 內(nèi)部的子View通過在布局中加app:layout_scrollFlags設(shè)置執(zhí)行的動作创译,app:layout_scrollFlags 也可以在代碼中通過setScrollFlags(int)設(shè)置 可以設(shè)置五種動作,下面一一介紹
五種滾動屬性介
- scroll:值設(shè)為scroll的View會跟隨滾動事件一起發(fā)生移動墙基。就是當指定的ScrollView發(fā)生滾動時软族,該View也跟隨一起滾動,就好像這個View也是屬于這個ScrollView一樣残制。在下面的代碼中 toolbar在滾動的時候 會向上滾出屏幕
- enterAlways:這個flag跟scroll一塊使用時立砸,向上滑動時ToolBar移出屏幕,我們向下滑動時Toolbar進入屏幕初茶。上面的圖給出的就是scroll|enterAlways這個兩個flag的效果颗祝。
- enterAlwaysCollapsed : enterAlways的附加值。這里涉及到appbarlayout 的Child View的高度和最小高度纺蛆,向下滾動時吐葵,Child View先向下滾動最小高度值,然后Scrolling View開始滾動桥氏,到達邊界時温峭,Child View再向下滾動,直至顯示完全字支。(要設(shè)置子view的最小高度)
- exitUntilCollapsed:這個跟上面的enterAlwaysCollapsed相反凤藏;它也涉及到minHeight,當發(fā)生向上滾動事件時堕伪,AppLayout向上滾動揖庄,直到我們設(shè)置的minHeight,然后我們的滑動View才開始滾動欠雌。就算我們滑動的view完全上滑完畢蹄梢,我們的AppBarLayout也會一直保留我們設(shè)置的minHeight顯示在屏幕的上方
- snap:滑動結(jié)束的時候可能會出現(xiàn) toolbar顯示不完全的樣子 這個屬性讓拖把人要么顯示完全 要么完全隱藏 這都是在ScrollView滑動停止之后的事情。
- 需要注意的是 scroll屬性是可以單獨設(shè)置的富俄。但是使用其他屬性srcoll屬性也必須一起設(shè)置
- 布局文件代碼 只是設(shè)置的屬性不同
<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="?android:attr/actionBarSize"
android:background="?attr/colorPrimary"
app:layout_scrollFlags="scroll" />
</android.support.design.widget.AppBarLayout>
將子view與ScrollView 聯(lián)系起來
- 網(wǎng)上大部分都是下面這種用法 TODO 但是我覺得我見過自定義Behavior的寫法禁炒,所以應(yīng)該是可以自己定義的
- 把ScrollView和AppBarLayout作為CoordinateLayout的子View,然后編寫一個Behavior霍比,在這個Behavior里面判斷當前的操作是應(yīng)該讓ScrollView時刻保持在AppBarLayout之下(即只要改變AppBarLayout的位置就可以一起滑動)幕袱,還是應(yīng)該讓ScrollView內(nèi)部滾動而不讓AppBarLayout位置發(fā)生變化等等這些需求,都是可以在Behavior里面處理的悠瞬。你可以去針對你的ScrollView編寫B(tài)ehavior们豌。然而涯捻,我們看到我們的AppBarLayout實現(xiàn)的功能比較復(fù)雜,如果我們自己去定義這樣的效果望迎,代碼非常復(fù)雜障癌,還要考慮很多方面,好在Android幫我們寫好啦擂煞,我們直接用就是了混弥,這個ScrollView就是NestedScrollView,請注意对省,它并沒有繼承ScrollView蝗拿,它繼承的是FrameLayout,但是它實現(xiàn)的效果把它可以看成是ScrollView蒿涎。
- 具體代碼如下
//注意外面有一層 CoordinateLayout 作為 NestedScrollView 和 AppBarLayout 的父布局 才可以使用 否則是是沒用的
<android.support.v4.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
<!--將你的內(nèi)容放在這里-->
</android.support.v4.widget.NestedScrollView>
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者