Android Toolbar,你想知道的都在這里了

Android 3.0之后,Google引入了ActionBar,想統(tǒng)一安卓應(yīng)用的導(dǎo)航欄樣式。但由于ActionBar難以定制,很大程度上限制了開發(fā)人員,比如標(biāo)題文字大小、間距等不易實(shí)現(xiàn)個性化,很多開發(fā)者放棄了ActionBar的使用,而是使用普通的ViewGroup來封裝自己的App Bar,或者使用JakeWharton大神ActionBarSherlock庫。

后來,自2014年Google I/O 上Material Design橫空出世后,市場上的應(yīng)用又逐步趨向了樣式的風(fēng)格統(tǒng)一,support library中很快就出來了Toolbar控件,一個定制化的ViewGroup,來完善ActionBar的使用,App Bar又迎來了春天。

基本使用


第一步,在Theme中隱藏現(xiàn)有的ActionBar,有以下兩種方式:

<style name="AppTheme.Base" parent="Theme.AppCompat">
    <item name="windowActionBar">false</item>
    <item name="android:windowNoTitle">true</item>
    ......
</style>

或者

<style name="AppTheme.Base" parent="heme.AppCompat.Light.NoActionBar">
    ......
</style>

第二步,在布局中添加v7包中的Toolbar控件(注意在builde.gradle文件中添加support.v7包的依賴:compile 'com.android.support:appcompat-v7:23.3.0'),如:

    <android.support.v7.widget.Toolbar
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:id="@+id/tb_toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        app:title="@string/app_name"
        app:titleTextColor="@android:color/white"
        android:background="@color/colorPrimary">

    </android.support.v7.widget.Toolbar>

第三步,在Activity代碼中使用Toolbar對象替換ActionBar:

Toolbar mToolbarTb = (Toolbar) findViewById(R.id.tb_toolbar);
setSupportActionBar(mToolbarTb);

效果如下:

oolbar-sample-01.png

諸如logo、title、subTitle、navigationIcon等,都可以通過app:xxx屬性和Java代碼來控制。titleTextAppearance、subtitleTextAppearance也可以用來控制標(biāo)題顏色和大小,如:

<style name="Theme.ToolBar.Base.Title" parent="@style/TextAppearance.Widget.AppCompat.Toolbar.Title">
    <item name="android:textSize">18sp</item>
    <item name="android:textColor">@android:color/white</item>
</style>

Options Menu


與ActionBar的用法一致,在menu資源目錄下新建一個search.xml文件,添加menu內(nèi)容,如:

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

    <item
        android:id="@+id/action_search"
        android:title="search"
        android:icon="@android:drawable/ic_menu_search"
        app:showAsAction="collapseActionView"/>

</menu>

在Java代碼中添加為Toolbar添加對應(yīng)的Menu Item,并設(shè)置點(diǎn)擊事件,如:

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.search, menu);
        return super.onCreateOptionsMenu(menu);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case R.id.action_search:
                //TODO search
                break;
        }
        return super.onOptionsItemSelected(item);
    }

效果如下:

toolbar-sample-02

如圖,溢出按鈕的顏色是黑色,那么怎么修改成與主題色搭配的白色呢?可以通過修改Toolbar的theme和popupTheme屬性來改變,在Toolbar中添加如下屬性:

    <android.support.v7.widget.Toolbar
        ......
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
        app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

    </android.support.v7.widget.Toolbar>

還有另一種方式,就是使用theme中的actionMenuTextColor屬性設(shè)置Menu Item的字體顏色,如:

    <style name="OverFlowMenuTheme" parent="Theme.AppCompat.NoActionBar">
        <item name="android:actionMenuTextColor">@android:color/white</item>
        <item name="overlapAnchor">false</item>
    </style>

Toolbar中的相關(guān)theme設(shè)置如下:

    <android.support.v7.widget.Toolbar
        ......
        app:popupTheme="@style/OverFlowMenuTheme"
        app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

    </android.support.v7.widget.Toolbar>

一般也是采用這種做法,將Toolbar相關(guān)屬性集中寫到一個style中,比如:

    <style name="OverFlowMenuTheme" parent="Theme.AppCompat.NoActionBar">
        <!-- 設(shè)置Menu菜單的背景色 -->
        <item name="android:itemBackground">@android:color/white</item>
        <!-- 設(shè)置Menu菜單的字體顏色 -->
        <item name="android:textColorPrimary">@android:color/black</item>
        <!-- 設(shè)置Menu窗口不覆蓋Toolbar視圖 -->
        <item name="overlapAnchor">false</item>
    </style>

這樣設(shè)置下的效果如下圖所示:

toolbar-sample-04.png

Up Enable


在二級界面等Activity中,通過如下設(shè)置可以在Toolbar左邊顯示一個返回按鈕:

getSupportActionBar().setDisplayHomeAsUpEnabled(true);

然后通過android.R.id.home監(jiān)聽返回按鈕的點(diǎn)擊事件,比如可以返回上級Activity中:

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case android.R.id.home:
                finish();
                break;
        }
        return super.onOptionsItemSelected(item);
    }

當(dāng)然,也可以通過為Toolbar設(shè)置導(dǎo)航圖標(biāo)的點(diǎn)擊事件來達(dá)到這個監(jiān)聽效果:

mToolbarTb.setNavigationOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        finish();
    }
});

顯示效果如下:

toolbar-sample-05.png

至于導(dǎo)航返回按鈕的圖標(biāo),可以通過mToolbarTb.setNavigationIcon方法或者app:navigationIcon屬性來修改。

標(biāo)題居中


前面我們說過,Toolbar就是一個定制化的ViewGroup,所以可以在Toolbar里面放置一個TextView控件作為居中的標(biāo)題來使用,再將Toolbar的Title隱藏起來即可實(shí)現(xiàn)Toolbar標(biāo)題居中的效果,如:

    <android.support.v7.widget.Toolbar
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:id="@+id/tb_toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        app:popupTheme="@style/OverFlowMenuTheme"
        app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        android:background="@color/colorPrimary">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:text="SecondActivity"
            style="@style/TextAppearance.AppCompat.Widget.ActionBar.Title"/>

    </android.support.v7.widget.Toolbar>

這里給TextView設(shè)置了style屬性,與ActionBar.Title保持一致,然后還需要去除Toolbar自有的Title,在布局中使用app:title=""是不會起作用的,會顯示ActionBar的標(biāo)題,所以在代碼中隱藏ActionBar的標(biāo)題即可:

getSupportActionBar().setDisplayShowTitleEnabled(false);

效果如下:

toolbar-sample-06.png

Fragment中使用


有時候需要在Fragment中使用Toolbar,比如Activity中不同的Tab顯示不同的Fragment,同時每個Tab的Toolbar標(biāo)題、Menu均不相同,這時在Activity中使用同一個Toolbar就相當(dāng)不方便了。我們可以在每個Fragment的布局中添加各自的Toolbar,然后在Fragment中單獨(dú)控制。

與Activity中使用Toolbar有所不同。替換ActionBar時,需要給setSupportActionBar方法添加作用對象:

((AppCompatActivity)getActivity()).setSupportActionBar((Toolbar) mContentView.findViewById(R.id.tb_toolbar));

添加Options Menu時,需要額外調(diào)用setHasOptionsMenu(true);方法,確保onCreateOptionsMenu()方法得以調(diào)用,并且onCreateOptionsMenu()方法多了一個MenuInflater參數(shù):

@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
    super.onCreateOptionsMenu(menu, inflater);
    inflater.inflate(R.menu.search, menu);
}

相關(guān)知識


關(guān)于Toolar的更多介紹可以從官網(wǎng)中學(xué)習(xí)借鑒,鏈接為:Adding the App Bar | Android Developers。從其使用上可以看出,Toolbar是ActionBar的一種替代解決方案,所以很多用法均可參考ActionBar,大家可以從郭神的譯文中掌握ActionBar的相關(guān)用法:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容