Android ToolBar 簡單實(shí)用

一 . Toobar 簡介

Toolbar是在 Android 5.0 開始推出的一個(gè) Material Design 風(fēng)格的導(dǎo)航控件体啰,以此來取代之前的Actionbar徊件。我們需要在工程中引入appcompat-v7的兼容包以便向下兼容塞栅, 使用android.support.v7.widget.Toolbar進(jìn)行開發(fā)

二. Toobar 實(shí)用

1, 引入support v7支持包

在你項(xiàng)目的build.gradle內(nèi)輸入如下代碼

dependencies {
    compile 'com.android.support:appcompat-v7:25.3.1'
  }

2,更換主題(兩種方式)

1,為了能夠正常使用ToolBar渠退,我們需要隱藏原來的ActionBar江解,這個(gè)可以在主題中修改繼承了Theme.Appcompat.Light.NoActionBar主題设预,在values/styles.xml中做出如下修改:

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
        // 改變右上角三個(gè)圓點(diǎn)的顏色
        <item name="android:textColorSecondary">@color/white</item>
    </style>
如果想要改變toolbar的title、subtitle以及menu中文字的顏色犁河,可以利用“textColorPrimary”屬性等鳖枕。

2,如果我們的MainActivity是繼承 AppCompatActivity則可以直接在BaseActivity中調(diào)用supportRequestWindowFeature(Window.FEATURE_NO_TITLE)去掉了默認(rèn)的導(dǎo)航欄,如果MainActivity是繼承Activity就應(yīng)該用requestWindowFeature(Window.FEATURE_NO_TITLE),這句話必須在setContentView(getLayout());方法之前實(shí)用.

3.在布局文件 activity_main.xml 中添加進(jìn)我們需要的 Toolbar 控件

也可以在布局中添加title桨螺、subtitle宾符、logo、導(dǎo)航欄圖標(biāo)
如果你想修改標(biāo)題和子標(biāo)題的字體大小灭翔、顏色等魏烫,可以調(diào)用 setTitleTextColor, setTitleTextAppearance肝箱, setSubtitleTextColor哄褒,setSubtitleTextAppearance 這些API;
同時(shí)我們在內(nèi)部放了一個(gè)TextView煌张,這是與ActionBar最大的不同呐赡,因?yàn)門oolBar實(shí)際上是一個(gè)ViewGroup,支持在其內(nèi)部放入子View骏融。

<android.support.v7.widget.Toolbar android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="?attr/actionBarSize"
    android:background="@color/colorPrimary"
    app:popupTheme="@style/ToolbarPopupTheme"
    app:navigationIcon="@drawable/ic_format_list_bulleted_white_24dp"
    app:logo="@mipmap/ic_launcher"
    app:subtitle="Title"
    app:title="Subtitle"
    app:titleTextColor="@color/white"
    android:titleTextAppearance="@dimen/sp18"
    android:subtitleTextAppearance="@dimen/sp14"
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
    <TextView
        android:id="@+id/tv_title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="標(biāo)題"
        android:textSize="@dimen/sp14"
        android:textColor="@color/white"
        />
</android.support.v7.widget.Toolbar>

4.在代碼中引用和添加title链嘀、subtitle、logo档玻、導(dǎo)航欄圖標(biāo)

如果你想修改標(biāo)題和子標(biāo)題的字體大小怀泊、顏色等,可以調(diào)用 setTitleTextColor误趴, setTitleTextAppearance霹琼, setSubtitleTextColor,setSubtitleTextAppearance

toolbar = (Toolbar) findViewById(R.id.toolbar);
toolbar.setTitle("Title");
toolbar.setSubtitle("SubTitle");
toolbar.setLogo(R.mipmap.ic_launcher);
//設(shè)置導(dǎo)航圖標(biāo)要在setSupportActionBar方法之后
setSupportActionBar(toolbar);
toolbar.setNavigationIcon(R.drawable.ic_format_list_bulleted_white_24dp);

5.添加菜單選項(xiàng)圖標(biāo)及點(diǎn)擊事件

1 在res/menu下添加新建一個(gè)base_toolbar_menu.xml并添加 action menu 菜單項(xiàng)
app:showAsAction="ifRoom"/"never"凉当,ifRoom表示有空間則顯示碧囊,never表示從不顯示,而是會(huì)通過overflowwindow顯示纤怒。

<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:icon="@drawable/ic_search_white_24dp"
        android:title="@string/menu_search"
        app:showAsAction="ifRoom" />
    <item
        android:id="@+id/action_notification"
        android:icon="@drawable/ic_notifications_white_24dp"
        android:title="@string/menu_notification"
        app:showAsAction="ifRoom"
        />
    <item
        android:id="@+id/action_item1"
        android:title="@string/menu_item1"
        app:showAsAction="never"/>
    <item
        android:id="@+id/action_item2"
        android:title="@string/menu_item2"
        app:showAsAction="never"/>
</menu>

2 在Activity中要重寫onCreateOptionsMenu()方法,把這個(gè)菜單加載進(jìn)去:

  @Override
    public boolean onCreatePanelMenu(int featureId, Menu menu) {
        getMenuInflater().inflate(R.menu.base_toolbar_menu, menu);
        return true;
    }

3 添加menu 菜單點(diǎn)擊事件

toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(MenuItem item) {
                switch (item.getItemId()){
                    case R.id.action_search:
                        ToastUitl.showShort("Search");
                        break;
                    case R.id.action_notification:
                        ToastUitl.showShort("Notification");
                        break;
                    case R.id.action_item1:
                        ToastUitl.showShort("Item1");
                        break;
                    case R.id.action_item2:
                        ToastUitl.showShort("Item2");
                        break;
                }
                return true;
            }
        });

6.修改Toolbar popup menu樣式

在布局文件中引用

  • toolbar:popupTheme="@style/ToolbarPopupTheme"
<style name="ToolbarPopupTheme" parent="@style/ThemeOverlay.AppCompat.Dark">
        <!--設(shè)置menu的背景顏色-->
        <item name="android:colorBackground">@color/white</item>
        <!--設(shè)置文本顏色-->
        <item name="android:textColor">@color/black</item>
        <!--設(shè)置menu彈出樣式-->
        <item name="actionOverflowMenuStyle">@style/OverflowMenuStyle</item>
    </style>
    <style name="OverflowMenuStyle" parent="Widget.AppCompat.Light.PopupMenu.Overflow">
        <!--把該屬性改為false即可使menu位置位于toolbar之下-->
        <item name="overlapAnchor">false</item>
    </style>

三. 最后的展示效果

1685240-043dee80cf9f44ab.gif
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末糯而,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子泊窘,更是在濱河造成了極大的恐慌熄驼,老刑警劉巖像寒,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異瓜贾,居然都是意外死亡诺祸,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門祭芦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來筷笨,“玉大人,你說我怎么就攤上這事。” “怎么了宇姚?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長仰禀。 經(jīng)常有香客問我,道長蚕愤,這世上最難降的妖魔是什么答恶? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮萍诱,結(jié)果婚禮上悬嗓,老公的妹妹穿的比我還像新娘。我一直安慰自己裕坊,他們只是感情好包竹,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著碍庵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪悟狱。 梳的紋絲不亂的頭發(fā)上静浴,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音挤渐,去河邊找鬼苹享。 笑死,一個(gè)胖子當(dāng)著我的面吹牛浴麻,可吹牛的內(nèi)容都是我干的得问。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼软免,長吁一口氣:“原來是場噩夢啊……” “哼宫纬!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起膏萧,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤漓骚,失蹤者是張志新(化名)和其女友劉穎蝌衔,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蝌蹂,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡噩斟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了孤个。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片剃允。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖齐鲤,靈堂內(nèi)的尸體忽然破棺而出斥废,到底是詐尸還是另有隱情,我是刑警寧澤佳遂,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布营袜,位于F島的核電站,受9級(jí)特大地震影響丑罪,放射性物質(zhì)發(fā)生泄漏荚板。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一吩屹、第九天 我趴在偏房一處隱蔽的房頂上張望跪另。 院中可真熱鬧,春花似錦煤搜、人聲如沸免绿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嘲驾。三九已至,卻和暖如春迹卢,著一層夾襖步出監(jiān)牢的瞬間辽故,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來泰國打工腐碱, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留誊垢,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓症见,卻偏偏與公主長得像喂走,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子谋作,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

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