Android CoordinatorLayout 實(shí)戰(zhàn)案例學(xué)習(xí)《二》

通過上一篇實(shí)戰(zhàn)案例,基本上能夠掌握CoordinatorLayout和AppBarLayout的初步使用怎诫。至此,Android Material Design系列的學(xué)習(xí)已進(jìn)行到第六篇,大家可以點(diǎn)擊以下鏈接查看之前的文章:

本文繼續(xù)以案例的方式學(xué)習(xí)CoordinatorLayout和AppBarLayout的使用甚脉,同時(shí)引入Desgin包中的一個新控件:CollapsingToolbarLayout丸升。效果圖如下:

Samples.gif

可以看到,Toolbar的標(biāo)題放大并在下方顯示宦焦,當(dāng)我們向上滑動列表時(shí)发钝,頂部Header部分的圖片向上折疊隱藏,標(biāo)題向上移動并縮小波闹,同時(shí)以漸顯式的方式顯示藍(lán)色主題酝豪,直至高度縮為Toolbar的高度并成為Toolbar的背景色;向下滑動列表時(shí)精堕,Header部分逐漸顯示孵淘。這個效果就是利用了CollapsingToolbarLayout控件,在講解案例代碼前歹篓,先來介紹一下CollapsingToolbarLayout瘫证。

CollapsingToolbarLayout


在 CollapsingToolbarLayout 的 Children 布局上,可以按照 FrameLayout 的屬性來拍版庄撮,因?yàn)樗旧砝^承于 FrameLayout :

CollapsingToolbarLayout.png

CollapsingToolbarLayout is a wrapper for Toolbar
which implements a collapsing app bar. It is designed to be used as a direct child of a AppBarLayout
.

從官方對CollapsingToolbarLayout的介紹上可以看出背捌,CollapsingToolbarLayout 是對 Toolbar 的一個包裝,以達(dá)到折疊 AppBar 的交互視覺效果洞斯。所以毡庆,CollapsingToolbarLayout 的使用一定離不開 AppBarLayout 和 Toolbar,并且作為 AppBarLayout 的直接子視圖使用烙如。

關(guān)于CollapsingToolbarLayout的屬性在官網(wǎng)上可以查到么抗,這里我只介紹案例中我們常用的幾個屬性:

  1. title
    標(biāo)題,布局展開時(shí)放大顯示在圖片底部亚铁,布局折疊時(shí)縮小顯示在Toolbar左側(cè)蝇刀。注意,沒有設(shè)置這個屬性時(shí)徘溢,默認(rèn)使用Toolbar的標(biāo)題吞琐;

  2. statusBarScrim
    頂部視圖折疊狀態(tài)下,狀態(tài)欄的遮罩色然爆。通常這樣設(shè)置:app:statusBarScrim="?attr/colorPrimaryDark"顽分,即style樣式中定義的沉浸式狀態(tài)欄顏色。這個屬性要和getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);(支持API19及以上版本施蜜,位于setContentView語句前面)一起使用卒蘸,使頂部視圖展開時(shí)圖片能夠延伸到狀態(tài)欄位置顯示,如效果圖中所示翻默;

  3. contentScrim
    內(nèi)容遮罩缸沃,上下滾動時(shí)圖片上面顯示和隱藏的遮罩色,Toolbar位置的的背景色修械;通常這樣設(shè)置:app:contentScrim="?attr/colorPrimary"趾牧,即顯示為Toolbar顏色,應(yīng)用的主題色肯污;

  4. layout_collapseMode
    折疊模式翘单,設(shè)置其他控件滾動時(shí)自身的交互行為吨枉,有兩種取值:parallax,折疊視差效果哄芜,比如上述效果圖中的圖片貌亭;pin,固定別針效果认臊,比如上圖中的Toolbar圃庭;

  5. layout_collapseParallaxMultiplier
    不折疊視差系數(shù),配合parallax模式使用失晴,取值有點(diǎn)類似alpha(不透明度)剧腻,在0.0 ~ 1.0之間,默認(rèn)值為0.5涂屁。當(dāng)設(shè)置為1.0书在,滾動列表時(shí)圖片不會折疊移動;

案例分析


通過上面的介紹拆又,相信大家對CollapsingToolbarLayout有了一個初步的認(rèn)識蕊温,我們再來看看如何配合CoordinatorLayoutAppBarLayoutToolbar來實(shí)現(xià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"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:fitsSystemWindows="true"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:title="Collapse"
            app:contentScrim="?attr/colorPrimary"
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            app:expandedTitleMarginStart="48dp"
            app:expandedTitleMarginEnd="64dp">

            <ImageView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:fitsSystemWindows="true"
                android:src="@mipmap/header"
                android:adjustViewBounds="true"
                app:layout_collapseMode="parallax"
                app:layout_collapseParallaxMultiplier="0.7"/>

            <android.support.v7.widget.Toolbar
                android:id="@+id/tb_toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
                app:titleTextColor="@color/white"
                app:title="@string/app_name"
                app:layout_collapseMode="pin"/>

        </android.support.design.widget.CollapsingToolbarLayout>

    </android.support.design.widget.AppBarLayout>

    <android.support.v7.widget.RecyclerView
        android:id="@+id/rv_content"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior" />

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab_add"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="@dimen/dp_16"
        android:src="@mipmap/ic_toolbar_add"
        app:layout_anchor="@id/appbar"
        app:layout_anchorGravity="bottom|right"
        app:backgroundTint="@color/fab_ripple"/>

</android.support.design.widget.CoordinatorLayout>

關(guān)于CoordinatorLayout作為根布局容器如何協(xié)調(diào)子控件之間的交互行為义矛,可以參考上一篇文章,這里我介紹一下本例中幾個新的注意點(diǎn)盟萨。

  1. 作為AppBarLayout的直接子控件凉翻,CollapsingToolbarLayout包裹Header部分的ImageView和Toolbar,并分別設(shè)置二者的折疊模式捻激。

  2. 這個例子制轰,我們給CollapsingToolbarLayoutlayout_scrollFlags屬性值設(shè)為:scroll|exitUntilCollapsed,其中exitUntilCollapsed表示控件向上折疊退出并以最小高度停留在頂部胞谭;

  3. 前面介紹CollapsingToolbarLayout屬性時(shí)介紹到了statusBarScrim的使用垃杖,其實(shí)也可以通過android:fitsSystemWindowsvalues-v21中style樣式的statusBarColor和windowDrawsSystemBarBackgrounds屬性來完成狀態(tài)欄的背景色變化,詳情參考源碼即可丈屹;

  4. 通過layout_anchorlayout_anchorGravity可以控制FloatingActionButton的behavior和位置调俘,如上圖所示,當(dāng)滾動列表是旺垒,F(xiàn)AB按鈕會隨著AppBarLayout而顯示和隱藏彩库,并自帶縮放動畫。

補(bǔ)充:對于這個案例先蒋,Google官方提供了一個效果圖骇钦,地址如下:
http://material-design.storage.googleapis.com/publish/material_v_4/material_ext_publish/0B6Okdz75tqQscXNQY3dNdVlYeTQ/patterns-scrolling-techniques_flex_space_image_xhdpi_003.webm

遺留問題


"AppBarLayout + RecyclerView"的組合使用會出現(xiàn)一些體驗(yàn)上的卡頓問題,目前已知的有兩個:

  1. AppBarLayout視圖處于顯示狀態(tài)的時(shí)候竞漾,ScrollingView的Fling事件容易出現(xiàn)卡頓眯搭,參考stackoverflowFlinging with RecyclerView + AppBarLayout窥翩;

  2. 當(dāng)AppBarLayout處于完全隱藏狀態(tài)時(shí),向下觸發(fā)Fling事件鳞仙,ScrollingView向上滾動直至頂部全部展示寇蚊,而不是繼續(xù)滾動使AppBarLayout的內(nèi)容得以展示。

替代解決方案繁扎,開源項(xiàng)目:Android-ObservableScrollView

示例源碼


我在GitHub上建立了一個Repository幔荒,用來存放整個Android Material Design系列控件的學(xué)習(xí)案例糊闽,會伴隨著文章逐漸更新完善梳玫,歡迎大家補(bǔ)充交流,Star地址:

https://github.com/Mike-bel/MDStudySamples

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末右犹,一起剝皮案震驚了整個濱河市提澎,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌念链,老刑警劉巖盼忌,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異掂墓,居然都是意外死亡谦纱,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門君编,熙熙樓的掌柜王于貴愁眉苦臉地迎上來跨嘉,“玉大人,你說我怎么就攤上這事吃嘿§裟耍” “怎么了?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵兑燥,是天一觀的道長亮瓷。 經(jīng)常有香客問我,道長降瞳,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任挣饥,我火速辦了婚禮斗塘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘亮靴。我一直安慰自己馍盟,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布茧吊。 她就那樣靜靜地躺著贞岭,像睡著了一般八毯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瞄桨,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天话速,我揣著相機(jī)與錄音,去河邊找鬼芯侥。 笑死泊交,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的柱查。 我是一名探鬼主播廓俭,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼唉工!你這毒婦竟也來了研乒?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤淋硝,失蹤者是張志新(化名)和其女友劉穎雹熬,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體谣膳,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡竿报,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了继谚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片烈菌。...
    茶點(diǎn)故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖犬庇,靈堂內(nèi)的尸體忽然破棺而出僧界,到底是詐尸還是另有隱情,我是刑警寧澤臭挽,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布捂襟,位于F島的核電站,受9級特大地震影響欢峰,放射性物質(zhì)發(fā)生泄漏葬荷。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一纽帖、第九天 我趴在偏房一處隱蔽的房頂上張望宠漩。 院中可真熱鬧,春花似錦懊直、人聲如沸扒吁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽雕崩。三九已至魁索,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間盼铁,已是汗流浹背粗蔚。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留饶火,地道東北人鹏控。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像肤寝,于是被迫代替她去往敵國和親当辐。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容