使用谷歌官方BottomNavigationView實現(xiàn)非md風格的底部狀態(tài)欄

先看效果


ezgif.com-video-to-gif.gif

谷歌原始模板代碼出來是這樣的:


image.png

我知道, 這個跟谷歌官方建議的效果完全不同, 但是奈何公司的設計就喜歡這種風格, 其實國內(nèi)的安卓app風格大都是在模仿ios.

廢話不多說, 下面列舉下遇到的問題

1. 怎么實現(xiàn)按下態(tài)的圖標顯示.


根據(jù)官方模板, 幾個按鈕tab的定義在navigation.xml中. 如下:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">

    <item
        android:id="@+id/navigation_home"
        android:icon="@drawable/ic_home_black_24dp"
        android:title="@string/title_home" />

    <item
        android:id="@+id/navigation_dashboard"
        android:icon="@drawable/ic_dashboard_black_24dp"
        android:title="@string/title_dashboard" />

    <item
        android:id="@+id/navigation_notifications"
        android:icon="@drawable/ic_notifications_black_24dp"
        android:title="@string/title_notifications" />

</menu>

修改這里的icon設置, 就可以修改圖標了 . 比如這樣:
../drawable/ic_home_black_24dp.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="false" android:drawable="@drawable/ic_home_page_normal"/>
    <item android:state_checked="true" android:drawable="@drawable/ic_home_page_selected"/>
</selector>

兩種狀態(tài)的圖標分別是:


image.png

image.png

因為這么修改了, 肯定就沒問題了, 然而出來的效果是這樣的:


image.png

image.png

為什么? 因為這里的圖標要求比較嚴格, 必須是鏤空的, 不能自定義顏色. 因為會有tint, 所以所有不鏤空的地方都會變成統(tǒng)一的tint顏色.
怎么辦? 說服設計接受這種高大上的風格? 好像不太可能.
研究了一下(百度搜了一圈), 發(fā)現(xiàn)這樣可以:
調(diào)用BottomNavigationView的setItemIconTintList(null) 傳遞null進去.
kotlin代碼navigation.itemIconTintList=null
這個問題算是解決了.

2. 選中一個tab標簽時, 不要有圖標變大的效果.


這個可以通過看BottomNavigationView源碼知道, 在布局文件中設置app:labelVisibilityMode="labeled"可以實現(xiàn)

<com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/navigation"
        android:layout_width="0dp"
        android:layout_height="50dp"
        android:paddingTop="0dp"
        android:background="#ffffff"
        app:itemIconSize="33dp"
        app:itemTextAppearanceActive="@style/bottom_tab_title_active"
        app:itemTextAppearanceInactive="@style/bottom_tab_title_inactive"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:menu="@menu/bottom_menu"
        app:labelVisibilityMode="labeled"/>

這個布局文件, 還包括了
修改圖標大小: app:itemIconSize="33dp"
修改標簽選中和非選中狀態(tài)的字體顏色, 字體大小:

        app:itemTextAppearanceActive="@style/bottom_tab_title_active"
        app:itemTextAppearanceInactive="@style/bottom_tab_title_inactive"

關于設置字體大小, 后面會看到還有另一種方法.

3. 調(diào)整圖標和標題的位置.


原始的效果, 雖然還可以, 但是我們高標準的設計小妹妹接受不了. 嘗試說服她? 不可能的!
這個問題搜了半天也沒找到怎么處理的辦法. 甚至打算放棄這東西了, 自己實現(xiàn)一個LinearLayout也能把這需求搞定啊, 何苦這么費勁. 但是之前的經(jīng)歷告訴我, 自己實現(xiàn)的話, 需要負責view的狀態(tài)保存和恢復, 這簡直太惡心了.
繼續(xù)看它的源碼實現(xiàn), 發(fā)現(xiàn)原來谷歌的這個東西是完全可以自定制的. 基本上包括所有的ui設置.

在BottomNavigationItemView這個類中, 發(fā)現(xiàn)每個item的布局加載:
LayoutInflater.from(context).inflate(layout.design_bottom_navigation_item, this, true);
我們可以自定義這個布局, 替換原始實現(xiàn), 從而隨意的定制自己的UI.
先看看谷歌的這個布局文件是怎么做的:
https://github.com/dandar3/android-support-design/blob/master/res/layout/design_bottom_navigation_item.xml
不列出來的. 然后依葫蘆畫瓢, 實現(xiàn)自己的一份:

<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    tools:override="true">

    <ImageView
        android:id="@+id/icon"
        android:layout_width="24dp"
        android:layout_height="24dp"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="@dimen/design_bottom_navigation_margin"
        android:layout_marginBottom="@dimen/design_bottom_navigation_margin"
        android:duplicateParentState="true" />


    <TextView
        android:id="@+id/smallLabel"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|center_horizontal"
        android:layout_marginBottom="0dp"
        android:duplicateParentState="true"
        android:text="small" />

    <TextView
        android:id="@+id/largeLabel"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|center_horizontal"
        android:layout_marginBottom="0dp"
        android:duplicateParentState="true"
        android:text="large"
        android:visibility="invisible" />
    <!--</FrameLayout>-->
</merge>

而且, 剛才上面提到的字體大小的控制, 也完全可以通過這種方式來實現(xiàn), 在dimens.xml中自定義一個同名的項目, 替換原來的默認值.

<dimen tools:override="true" name="design_bottom_navigation_text_size">14sp</dimen>
<dimen tools:override="true" name="design_bottom_navigation_active_text_size">14sp</dimen>

好了, 解決了以上幾個問題之后, 我的底部tab欄終于實現(xiàn)了.

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末隶校,一起剝皮案震驚了整個濱河市啤挎,隨后出現(xiàn)的幾起案子郁轻,更是在濱河造成了極大的恐慌庄涡,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件戴卜,死亡現(xiàn)場離奇詭異逾条,居然都是意外死亡,警方通過查閱死者的電腦和手機投剥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進店門师脂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人江锨,你說我怎么就攤上這事吃警。” “怎么了啄育?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵酌心,是天一觀的道長。 經(jīng)常有香客問我挑豌,道長安券,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任氓英,我火速辦了婚禮侯勉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘铝阐。我一直安慰自己址貌,他們只是感情好,可當我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著练对,像睡著了一般遍蟋。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上螟凭,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天虚青,我揣著相機與錄音,去河邊找鬼赂摆。 笑死挟憔,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的烟号。 我是一名探鬼主播,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼政恍,長吁一口氣:“原來是場噩夢啊……” “哼汪拥!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起篙耗,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤迫筑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后宗弯,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體脯燃,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年蒙保,在試婚紗的時候發(fā)現(xiàn)自己被綠了辕棚。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡邓厕,死狀恐怖逝嚎,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情详恼,我是刑警寧澤补君,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站昧互,受9級特大地震影響挽铁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜敞掘,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一叽掘、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧渐逃,春花似錦够掠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽赊堪。三九已至,卻和暖如春竖哩,著一層夾襖步出監(jiān)牢的瞬間哭廉,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工相叁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留遵绰,地道東北人。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓增淹,卻偏偏與公主長得像椿访,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子虑润,可洞房花燭夜當晚...
    茶點故事閱讀 42,792評論 2 345