ToolBar詳解

1.概述

本篇就為各位介紹 – toolbar大渤,這是用來取代過去 actionbar 的控件,而現(xiàn)在于 material design 中也對之有一個統(tǒng)一名稱:app bar莹弊,在未來的 android app 中,就以 toolbar 這個元件來實作之。
接下來將為各位分成幾個階段進(jìn)行說明具温,如何在 android app 中用 toolbar 這個控件來做出一個基本的 app bar 嘍掠拳。

2.最簡單的使用

從以下三個步驟來使用:
(1) 風(fēng)格 (style)
(2) 界面 (layout)
(3) 程序 (java)

(1)風(fēng)格(隱藏ActionBar)

風(fēng)格要調(diào)整的地方有二

一在 res/values/styles.xml中

二在 /res/values-v21/styles.xml中

為了之后設(shè)定方便癞揉,我們先在 res/values/styles.xml 里增加一個名為 AppTheme.Base 的風(fēng)格

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

因為此范例只使用 Toolbar,所以我們要將讓原本的 ActionBar 隱藏起來,然后將原本 AppTheme 的 parent 屬性 改為上面的AppTheme.Base喊熟,代碼如下:

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

再來調(diào)整Android 5.0的style: /res/values-v21/styles.xml柏肪,也將其 parent 屬性改為 AppTheme.Base:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="AppTheme" parent="AppTheme.Base">
    </style>
</resources>

(2)界面

在 activity_main.xml 里面添加 Toolbar 控件:

<android.support.v7.widget.Toolbar
  android:id="@+id/toolbar"
  android:layout_height="?attr/actionBarSize"
  android:layout_width="match_parent" >
 
</android.support.v7.widget.Toolbar>

請記得用 support v7 里的 toolbar,不然只有 API Level 21 也就是 Android 5.0 以上的版本才能使用芥牌。

(3)程序

在 MainActivity.java 中加入 Toolbar 的聲明:

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);

通過以上三個步驟预吆,就可以實現(xiàn)ToolBar最簡單的使用了。

3.自定義顏色

(1)colorPrimaryDark(狀態(tài)欄底色):在風(fēng)格 (styles) 或是主題 (themes) 里進(jìn)行設(shè)定胳泉。

(2)App bar 底色
這個設(shè)定分為二拐叉,若你的 android app 仍是使用 actionbar ,則直接在風(fēng)格 (styles) 或是主題 (themes) 里進(jìn)行設(shè)定 colorPrimary 參數(shù)即可扇商;
可若是采用 toolbar 的話凤瘦,則要在界面 (layout) 里面設(shè)定 toolbar 控件的 background 屬性。

(3)navigationBarColor(導(dǎo)航欄底色):
僅能在 API v21 也就是 Android 5 以后的版本中使用案铺, 因此要將之設(shè)定在 res/values-v21/styles.xml 里面蔬芥。

也因此在這個階段,我們需要設(shè)定的地方有三:

一是 style中(res/values/styles.xml)

<style name="AppTheme.Base" parent="Theme.AppCompat">

  <item name="windowActionBar">false</item>
  <item name="android:windowNoTitle">true</item>

  <!-- Actionbar color -->
  <item name="colorPrimary">@color/accent_material_dark</item>

  <!--Status bar color-->
  <item name="colorPrimaryDark">@color/accent_material_light</item>

  <!--Window color-->
  <item name="android:windowBackground">@color/dim_foreground_material_dark</item>

</style>

再來是 v21 的style中 (res/values-v21/styles.xml)

<style name="AppTheme" parent="AppTheme.Base">

  <!--Navigation bar color-->
  <item name="android:navigationBarColor">@color/accent_material_light</item>

</style>

最后控汉,就是為了本篇的主角 – Toolbar 的 background 進(jìn)行設(shè)定笔诵。

<android.support.v7.widget.Toolbar
  android:id="@+id/toolbar"
  android:layout_height="?attr/actionBarSize"
  android:layout_width="match_parent"
  android:background="?attr/colorPrimary" >
 
</android.support.v7.widget.Toolbar>

在本范例中,toolbar 是設(shè)定來在 activity_main.xml姑子,對其設(shè)定 background 屬性: android:background="?attr/colorPrimary" 乎婿,這樣就可以使之延用 Actionbar 的顏色設(shè)定嘍。

4.控件

  • (1)setNavigationIcon
    即設(shè)定 up button 的圖標(biāo)街佑,因為 Material 的介面谢翎,在 Toolbar這里的 up button樣式也就有別于過去的 ActionBar 哦。
  • (2)setLogo
    APP 的圖標(biāo)沐旨。
  • (3)setTitle
    主標(biāo)題森逮。
  • (4)setSubtitle
    副標(biāo)題。
  • (5)setOnMenuItemClickListener
    設(shè)定菜單各按鈕的動作磁携。

(1)先來看看菜單外的代碼褒侧,在 MainActivity.java 中:

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
 
// App Logo
toolbar.setLogo(R.drawable.ic_launcher);
// Title
toolbar.setTitle("My Title");
// Sub Title
toolbar.setSubtitle("Sub title");
 
setSupportActionBar(toolbar);
 
// Navigation Icon 要設(shè)定在 setSupoortActionBar 才有作用
// 否則會出現(xiàn) back button
toolbar.setNavigationIcon(R.drawable.ab_android);

這邊要留意的是setNavigationIcon需要放在 setSupportActionBar之后才會生效。

(2)菜單部分谊迄,需要先在res/menu/menu_main.xml左定義:

<menu 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"
      tools:context=".MainActivity">
 
  <item android:id="@+id/action_edit"
        android:title="@string/action_edit"
        android:orderInCategory="80"
        android:icon="@drawable/ab_edit"
        app:showAsAction="ifRoom" />
 
  <item android:id="@+id/action_share"
        android:title="@string/action_edit"
        android:orderInCategory="90"
        android:icon="@drawable/ab_share"
        app:showAsAction="ifRoom" />
 
  <item android:id="@+id/action_settings"
        android:title="@string/action_settings"
        android:orderInCategory="100"
        app:showAsAction="never"/>
</menu>

再回到MainActivity.java 中加入OnMenuItemClickListener 的監(jiān)聽者:

private Toolbar.OnMenuItemClickListener onMenuItemClick = new Toolbar.OnMenuItemClickListener() {
  @Override
  public boolean onMenuItemClick(MenuItem menuItem) {
    String msg = "";
    switch (menuItem.getItemId()) {
      case R.id.action_edit:
        msg += "Click edit";
        break;
      case R.id.action_share:
        msg += "Click share";
        break;
      case R.id.action_settings:
        msg += "Click setting";
        break;
    }
 
    if(!msg.equals("")) {
      Toast.makeText(MainActivity.this, msg, Toast.LENGTH_SHORT).show();
    }
    return true;
  }
};

將onMenuItemClick監(jiān)聽者設(shè)置給toolbar

setSupportActionBar(toolbar);
 
...
 
// Menu item click 的監(jiān)聽事件一樣要設(shè)定在 setSupportActionBar 才有作用
toolbar.setOnMenuItemClickListener(onMenuItemClick);

和 setNavigationIcon 一樣闷供,需要將之設(shè)定在 setSupportActionBar 之后才有作用。執(zhí)行上面的代碼便會得到下面的界面鳞上。

5.附上一個界面上常用的屬性

  • colorPrimaryDark
    狀態(tài)欄背景色这吻。
    在 style 的屬性中設(shè)置。
    textColorPrimary

  • App bar 上的標(biāo)題與更多菜單中的文字顏色篙议。
    在 style 的屬性中設(shè)置唾糯。
    App bar 的背景色

  • Actionbar 的背景色設(shè)定在 style 中的 colorPrimary怠硼。
    Toolbar 的背景色在layout文件中設(shè)置background屬性。
    colorAccent

  • 各控制元件(如:check box移怯、switch 或是 radoi) 被勾選 (checked) 或是選定 (selected) 的顏色香璃。
    在 style 的屬性中設(shè)置。
    colorControlNormal

  • 各控制元件的預(yù)設(shè)顏色舟误。
    在 style 的屬性中設(shè)置
    windowBackground

  • App 的背景色葡秒。
    在 style 的屬性中設(shè)置
    navigationBarColor

  • 導(dǎo)航欄的背景色,但只能用在 API Level 21 (Android 5) 以上的版本
    在 style 的屬性中設(shè)置

參考

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末嵌溢,一起剝皮案震驚了整個濱河市眯牧,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌赖草,老刑警劉巖学少,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異秧骑,居然都是意外死亡版确,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進(jìn)店門乎折,熙熙樓的掌柜王于貴愁眉苦臉地迎上來绒疗,“玉大人,你說我怎么就攤上這事骂澄∠拍ⅲ” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵酗洒,是天一觀的道長士修。 經(jīng)常有香客問我,道長樱衷,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任酒唉,我火速辦了婚禮矩桂,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘痪伦。我一直安慰自己侄榴,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布网沾。 她就那樣靜靜地躺著癞蚕,像睡著了一般。 火紅的嫁衣襯著肌膚如雪辉哥。 梳的紋絲不亂的頭發(fā)上桦山,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天攒射,我揣著相機(jī)與錄音,去河邊找鬼恒水。 笑死会放,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的钉凌。 我是一名探鬼主播咧最,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼御雕!你這毒婦竟也來了矢沿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤酸纲,失蹤者是張志新(化名)和其女友劉穎咨察,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體福青,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡摄狱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了无午。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片媒役。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖宪迟,靈堂內(nèi)的尸體忽然破棺而出酣衷,到底是詐尸還是另有隱情,我是刑警寧澤次泽,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布穿仪,位于F島的核電站,受9級特大地震影響意荤,放射性物質(zhì)發(fā)生泄漏啊片。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一玖像、第九天 我趴在偏房一處隱蔽的房頂上張望紫谷。 院中可真熱鬧,春花似錦捐寥、人聲如沸笤昨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽瞒窒。三九已至,卻和暖如春乡洼,著一層夾襖步出監(jiān)牢的瞬間崇裁,已是汗流浹背匕坯。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留寇壳,地道東北人醒颖。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像壳炎,于是被迫代替她去往敵國和親泞歉。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,877評論 2 345

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