Snackbar的使用和頂部Snackbar實(shí)現(xiàn)

谷歌在android 5.0 發(fā)布后雀扶,隨后公布了design庫和設(shè)計(jì)理念(需翻墻)焰络,意圖在于規(guī)范安卓app的風(fēng)格弦叶,類似而不僅僅ios的扁平風(fēng)。我認(rèn)為每個(gè)android的開發(fā)和設(shè)計(jì)人員都應(yīng)該看一看這個(gè)抱环,站在巨人的肩膀上摘甜品何樂而不為。

之前寫的是基于design支持包25版本的API,沒想到的是snackbar在升級(jí)后的源碼發(fā)生了改變镇草,這版是基于android 8.0sdk眶痰、design 26.1.0gradle 4.1陶夜、android studio 3.0.1所編寫凛驮。
??下面進(jìn)入正題。首先我們需要集成design庫:
????implementation 'com.android.support:design:26.1.0'

庫中分別有FloatingActionButton(懸浮操作按鈕)条辟、CollapsingToolbarLayout(可伸縮折疊的ToolBar)黔夭、TabLayout(選項(xiàng)卡)、Snackbar等組件羽嫡。今天只說Snackbar本姥,官方文檔在此,英文好的少年建議先看官方文檔杭棵。先放一張爛大街的圖

Snackbar

Snackbar的出現(xiàn)旨在替換Toast婚惫。它比Toast的拓展性更高,源碼相對(duì)比較簡(jiǎn)單魂爪。使用方法也和Toast極其類似先舷。可以透過源碼看到它的顯示主體叫做SnackbarLayout滓侍,一個(gè)內(nèi)部類蒋川,繼承于LinearLayout。所以Snackbar就是一個(gè)LinearLayout撩笆。其public方法主要有以下幾個(gè):


make(View view, CharSequence text, int duration)

這個(gè)靜態(tài)方法是使用Snackbar的入口捺球,因?yàn)镾nackbar的構(gòu)造是私有的。第一個(gè)參數(shù)是一個(gè)View夕冲。這個(gè)view可以傳子view氮兵,傳進(jìn)去會(huì)判斷并拿到根ViewGroup,Snackbar即添加到此ViewGroup歹鱼。判斷方法如下
<pre><code>
private static ViewGroup findSuitableParent(View view) {

    ViewGroup fallback = null;
    do {
        if (view instanceof CoordinatorLayout) {
            return (ViewGroup) view;
        } else if (view instanceof FrameLayout) {
            if (view.getId() == android.R.id.content) {
                return (ViewGroup) view;
            } else {
                fallback = (ViewGroup) view;
            }
        }
        if (view != null) {
            final ViewParent parent = view.getParent();
            view = parent instanceof View ? (View) parent : null;
        }
    } while (view != null);
    return fallback;

}
</pre></code>
??第二個(gè)參數(shù)是Snackbar顯示的文字內(nèi)容泣栈,可以穿字符串,也可以傳string resID弥姻,不再累述秩霍。
??第三個(gè)參數(shù)是顯示時(shí)長(zhǎng),三個(gè)值供選擇:

名稱 意義
LENGTH_INDEFINITE 始終顯示蚁阳,點(diǎn)擊Snackbar上的按鈕才會(huì)消失
LENGTH_SHORT 顯示1500毫秒
LENGTH_LONG 顯示2750毫秒

setText(CharSequence message)

修改文字铃绒,可穿字符串和string resID。

setAction(CharSequence text, final View.OnClickListener listener)

第一個(gè)參數(shù)設(shè)置點(diǎn)擊部分的文字螺捐。第二個(gè)參數(shù)則是給Snackbar設(shè)置點(diǎn)擊事件颠悬,不需要再在onClick里去寫dismiss矮燎,點(diǎn)擊事件執(zhí)行完會(huì)自動(dòng)dismiss。

setActionTextColor(ColorStateList colors)

設(shè)置按鈕文字顏色赔癌,可傳色值和color resID诞外。

setCallback(Callback callback)

給Snackbar添加一個(gè)顯示和隱藏的監(jiān)聽,分別對(duì)應(yīng)Callback接口里的onShown和onDismissed方法灾票。

show()和dismiss()

顯示和隱藏峡谊。


說了這么多,其實(shí)就是3行代碼:
Snackbar.make(parentLayout, R.string.snackbar_text,Snackbar.LENGTH_LONG) .setAction(R.string.snackbar_action, myOnClickListener) .show();

以上就是Snackbar的使用方法刊苍。感覺好像少了點(diǎn)什么既们?沒錯(cuò),Snackbar只能在底部顯示正什!可是我想把提示做在頂部啥纸,沒辦法只好把Snackbar的源碼拷貝出來,自己動(dòng)手改!不先看效果的文章不是好作者婴氮,上一張效果圖:

demo.gif

??我們需要從源碼中拷貝6個(gè)類:AnimationUtils.java斯棒、BaseTransientBottomBar.java、Snackbar.java主经、SnackbarManager.java荣暮、SnackbarContentLayout.java、ThemeUtils.java罩驻,兩個(gè)布局文件:design_layout_snackbar.xml渠驼、design_layout_snackbar_include.xml。建議把Snackbar.java鉴腻、design_layout_snackbar.xml和design_layout_snackbar_include.xml的名字改了。下面開始修改源碼:
??首先百揭,我們打開BaseTransientBottomBar.java爽哎,里面的animateViewIn()animateViewOut()就是定義Snackbar彈出動(dòng)畫和彈入動(dòng)畫的方法。在in方法里器一,可以看到定義動(dòng)畫初始Y坐標(biāo)是給了一個(gè)mView.getHeight()的值课锌,我們給改成負(fù)的,即-mView.getHeight()祈秕。移步out方法渺贤,可以看到定義了一個(gè)動(dòng)畫結(jié)束的Y坐標(biāo)是mView.getHeight(),再改成負(fù)的-mView.getHeight()请毛,但是這還不夠志鞍,還需要在方法伊始加上ViewCompat.setTranslationY(mView, 0);這句,定義動(dòng)畫初始Y軸坐標(biāo)為0方仿。
??最后再把design_layout_snackbar.xml里的layout_gravitybottom改為top固棚,class改為自己拷出來的SnackBarLayout统翩;把design_layout_snackbar_include.xml中的class改為自己拷出來的SnackbarContentLayout。至此此洲,你的Snackbar就變成在頂部的了厂汗。如需頂部底部都支持請(qǐng)自己封裝...因?yàn)槲姨Я恕?br> ??demo地址:http://pan.baidu.com/s/1cvwF7K

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末呜师,一起剝皮案震驚了整個(gè)濱河市娶桦,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌汁汗,老刑警劉巖衷畦,帶你破解...
    沈念sama閱讀 210,914評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異碰酝,居然都是意外死亡霎匈,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評(píng)論 2 383
  • 文/潘曉璐 我一進(jìn)店門送爸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來铛嘱,“玉大人,你說我怎么就攤上這事袭厂∧牛” “怎么了?”我有些...
    開封第一講書人閱讀 156,531評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵纹磺,是天一觀的道長(zhǎng)帖烘。 經(jīng)常有香客問我,道長(zhǎng)橄杨,這世上最難降的妖魔是什么秘症? 我笑而不...
    開封第一講書人閱讀 56,309評(píng)論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮式矫,結(jié)果婚禮上乡摹,老公的妹妹穿的比我還像新娘。我一直安慰自己采转,他們只是感情好聪廉,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著故慈,像睡著了一般板熊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上察绷,一...
    開封第一講書人閱讀 49,730評(píng)論 1 289
  • 那天干签,我揣著相機(jī)與錄音,去河邊找鬼拆撼。 笑死筒严,一個(gè)胖子當(dāng)著我的面吹牛丹泉,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鸭蛙,決...
    沈念sama閱讀 38,882評(píng)論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼摹恨,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了娶视?” 一聲冷哼從身側(cè)響起晒哄,我...
    開封第一講書人閱讀 37,643評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎肪获,沒想到半個(gè)月后寝凌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡孝赫,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評(píng)論 2 325
  • 正文 我和宋清朗相戀三年较木,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片青柄。...
    茶點(diǎn)故事閱讀 38,566評(píng)論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡伐债,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出致开,到底是詐尸還是另有隱情峰锁,我是刑警寧澤,帶...
    沈念sama閱讀 34,253評(píng)論 4 328
  • 正文 年R本政府宣布双戳,位于F島的核電站虹蒋,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏飒货。R本人自食惡果不足惜魄衅,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望塘辅。 院中可真熱鬧晃虫,春花似錦、人聲如沸莫辨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽沮榜。三九已至,卻和暖如春喻粹,著一層夾襖步出監(jiān)牢的瞬間蟆融,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評(píng)論 1 264
  • 我被黑心中介騙來泰國打工守呜, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留型酥,地道東北人山憨。 一個(gè)月前我還...
    沈念sama閱讀 46,248評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像弥喉,于是被迫代替她去往敵國和親郁竟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評(píng)論 2 348