BottomNavigationView的使用

不多說(shuō)先上效果圖

zhouchatian.com

添加依賴(lài)

compile 'com.android.support:design:25.0.0'

添加控件

在布局文件添加BottomNavigationView組件

<RelativeLayout 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"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.zhouchatian.baseandroid.MainActivity">

    <TextView
        android:id="@+id/text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="18sp"
        android:layout_centerInParent="true"/>

    <android.support.design.widget.BottomNavigationView
        android:id="@+id/navigation"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        app:menu="@menu/navigation"/>

</RelativeLayout>

添加按鈕

在res下創(chuàng)建navigation.xml 放在menu文件夾下堵漱,如果沒(méi)有就創(chuàng)建一個(gè)menu文件夾

<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:id="@+id/bottom_home"
        android:icon="@mipmap/ic_home_white_24dp"
        android:title="首頁(yè)" />
    <item
        android:id="@+id/bottom_book"
        android:icon="@mipmap/ic_book_white_24dp"
        android:title="書(shū)本" />

    <item
        android:id="@+id/bottom_collection"
        android:icon="@mipmap/ic_favorite_white_24dp"
        android:title="收藏"/>

    <item
        android:id="@+id/bottom_setting"
        android:icon="@mipmap/ic_tv_white_24dp"
        android:title="設(shè)置" />
</menu>

要說(shuō)下的這個(gè)按鈕只能創(chuàng)建3個(gè)到5個(gè)级零,多了或少了都會(huì)報(bào)錯(cuò)。

添加監(jiān)聽(tīng)

public class MainActivity extends AppCompatActivity {
    private TextView mTextView;
    private BottomNavigationView mNavigationView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTextView = (TextView) findViewById(R.id.text);
        mNavigationView = (BottomNavigationView) findViewById(R.id.navigation);
        mNavigationView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem item) {
                mTextView.setText(item.getTitle().toString().toUpperCase());
                return true;
            }
        });
    }
}

這樣一個(gè)建的底部導(dǎo)航就做好了笔横,控件使用簡(jiǎn)單,帶來(lái)局限性烁巫,只有修改一些奢人。

修改

app:itemIconTint="#FFFFFF"設(shè)置圖標(biāo)的顏色

app:itemTextColor="#FFFFFF"設(shè)置文字的顏色

app:itemBackground="@color/colorPrimary" 設(shè)置背景色

如果不設(shè)置就是上圖的顏色闸昨,官方提供了三個(gè)顏色

2017-04-25_211939.png
<android.support.design.widget.BottomNavigationView
        android:id="@+id/navigation"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        app:itemIconTint="#FFFFFF"
        app:itemTextColor="#FFFFFF"
        app:itemBackground="@color/colorPrimary"
        app:menu="@menu/navigation"/>

當(dāng)然你也可以在代碼中設(shè)置

setItemBackgroundResource(int resId)
setItemIconTintList(ColorStateList tint)
setItemTextColor(ColorStateList textColor)

在實(shí)際開(kāi)發(fā)中使用item.getItemId()使用switch來(lái)判斷選中了哪一個(gè)

mNavigationView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem item) {
                switch (item.getItemId()) {
                    case R.id.bottom_home:
                        mTextView.setText(item.getTitle());
                        break;
                    case R.id.bottom_book:
                        mTextView.setText(item.getTitle());
                        break;
                    case R.id.bottom_collection:
                        mTextView.setText(item.getTitle());
                        break;
                    case R.id.bottom_setting:
                        mTextView.setText(item.getTitle());
                        break;
                }
                return true;
            }
        });

其實(shí)這個(gè)還有另外一個(gè)監(jiān)聽(tīng)

BottomNavigationView.OnNavigationItemReselectedListener

官方解釋用于重選的監(jiān)聽(tīng)风纠,特意提下是希望各位用的時(shí)候別選錯(cuò)了况鸣。

問(wèn)題

1. 默認(rèn)選中的是第一個(gè),但是我們要默認(rèn)選中其他的怎么辦竹观?

在menu.xml中使用 android:checked="true"

<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:id="@+id/bottom_home"
        android:icon="@mipmap/ic_home_white_24dp"
        android:title="首頁(yè)" />
    <item
        android:id="@+id/bottom_book"
        android:icon="@mipmap/ic_book_white_24dp"
        android:title="書(shū)本" />

    <item
        android:id="@+id/bottom_collection"
        android:icon="@mipmap/ic_favorite_white_24dp"
        android:title="收藏"
        android:checked="true"/>

    <item
        android:id="@+id/bottom_setting"
        android:icon="@mipmap/ic_tv_white_24dp"
        android:title="設(shè)置" />
</menu>

或者代碼中這么寫(xiě)

mNavigationView.getMenu().getItem(0).setChecked(false);
        mNavigationView.getMenu().getItem(2).setChecked(true);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末镐捧,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子臭增,更是在濱河造成了極大的恐慌愤估,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件速址,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡由驹,警方通過(guò)查閱死者的電腦和手機(jī)芍锚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蔓榄,“玉大人并炮,你說(shuō)我怎么就攤上這事∩#” “怎么了逃魄?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,747評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)澜搅。 經(jīng)常有香客問(wèn)我伍俘,道長(zhǎng)邪锌,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,939評(píng)論 1 295
  • 正文 為了忘掉前任癌瘾,我火速辦了婚禮觅丰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘妨退。我一直安慰自己妇萄,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布咬荷。 她就那樣靜靜地躺著冠句,像睡著了一般。 火紅的嫁衣襯著肌膚如雪幸乒。 梳的紋絲不亂的頭發(fā)上懦底,一...
    開(kāi)封第一講書(shū)人閱讀 51,737評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音逝变,去河邊找鬼基茵。 笑死,一個(gè)胖子當(dāng)著我的面吹牛壳影,可吹牛的內(nèi)容都是我干的拱层。 我是一名探鬼主播,決...
    沈念sama閱讀 40,448評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼宴咧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼根灯!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起掺栅,我...
    開(kāi)封第一講書(shū)人閱讀 39,352評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤烙肺,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后氧卧,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體桃笙,經(jīng)...
    沈念sama閱讀 45,834評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評(píng)論 3 338
  • 正文 我和宋清朗相戀三年沙绝,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了搏明。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,133評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡闪檬,死狀恐怖星著,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情粗悯,我是刑警寧澤虚循,帶...
    沈念sama閱讀 35,815評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響横缔,放射性物質(zhì)發(fā)生泄漏铺遂。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評(píng)論 3 331
  • 文/蒙蒙 一剪廉、第九天 我趴在偏房一處隱蔽的房頂上張望娃循。 院中可真熱鬧,春花似錦斗蒋、人聲如沸捌斧。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,022評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)捞蚂。三九已至,卻和暖如春跷究,著一層夾襖步出監(jiān)牢的瞬間姓迅,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,147評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工俊马, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留丁存,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,398評(píng)論 3 373
  • 正文 我出身青樓柴我,卻偏偏與公主長(zhǎng)得像解寝,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子艘儒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評(píng)論 2 355

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