Android Material Design 之 Toolbar

前言

從 Android 3.0 開(kāi)始浴滴,推出了 ActionBar。但是岁钓,隨著版本的升級(jí)升略,ActionBar 的行為也發(fā)生了變化。從 5.0 開(kāi)始屡限,ActionBar 提供了 Material Design 的體驗(yàn)品嚣。但是想要 5.0 之前的系統(tǒng)也支持 Material Design 怎么辦呢?那么就用 Toolbar 吧钧大!Toolbar 在 Support Library 中翰撑,所有對(duì)應(yīng)的系統(tǒng)版本都能有 Material Design 的體驗(yàn)。

Toolbar 的簡(jiǎn)單使用

首先添加 v7 appcompat 庫(kù)

compile 'com.android.support:appcompat-v7:25.4.0'

為了能夠用 Toolbar啊央,我們需要隱藏原來(lái)的 ActionBar眶诈。
通過(guò)設(shè)置主題來(lái)隱藏

    <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>
    </style>

或者也可以添加屬性來(lái)隱藏

    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
        <item name="windowActionBar">false</item>
        <item name="windowNoTitle">true</item>
    </style>

下面介紹 Toolbar 的幾個(gè)屬性
先來(lái)看看布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <android.support.v7.widget.Toolbar
        android:id="@+id/tool_bar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/colorPrimary"
        app:logo="@drawable/ic_android_white"
        app:navigationIcon="@drawable/ic_menu_white"
        app:subtitle="subtitle"
        app:subtitleTextAppearance="@style/MySubTitleStyle"
        app:subtitleTextColor="@android:color/white"
        app:title="Toolbar"
        app:titleMarginStart="30dp"
        app:titleTextAppearance="@style/MyTitleStyle"
        app:titleTextColor="@android:color/white" />

</LinearLayout>

app:navigationIcon:設(shè)置 NavigationIcon,位于 Toolbar 的最左邊
app:logo:設(shè)置 Logo瓜饥,位于 NavigationIcon 的右邊逝撬,Title 的左邊
app:title:設(shè)置標(biāo)題
app:titleTextColor:設(shè)置標(biāo)題顏色
app:titleTextAppearance:設(shè)置標(biāo)題樣式(字體大小,字體顏色乓土,等等)
app:titleMarginStart:設(shè)置標(biāo)題左邊的 Margin宪潮,類(lèi)似的還有
app:titleMargin溯警、app:titleMarginTop、app:titleMarginBottom狡相、app:titleMarginEnd
app:subtitle:設(shè)置副標(biāo)題
app:subtitleTextColor:設(shè)置副標(biāo)題顏色
app:subtitleTextAppearance:設(shè)置副標(biāo)題樣式(字體大小梯轻,字體顏色,等等)

MyTitleStyle 和 MySubTitleStyle 如下

    <style name="MyTitleStyle" parent="TextAppearance.Widget.AppCompat.Toolbar.Title">
        <item name="android:textSize">20sp</item>
    </style>

    <style name="MySubTitleStyle" parent="TextAppearance.Widget.AppCompat.Toolbar.Subtitle">
        <item name="android:textSize">10sp</item>
    </style>

Activity 中的代碼如下

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

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

運(yùn)行效果如下

添加 Navigation Icon 的點(diǎn)擊事件

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

        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(MainActivity.this, "Navigation Icon Clicked!", Toast.LENGTH_SHORT).show();
            }
        });

Toolbar 添加 Action Menu

Toolbar 和 ActionBar 一樣尽棕,也可以添加 Action Menu喳挑。
覆寫(xiě) onCreateOptionsMenu 添加 Menu,覆寫(xiě) onOptionsItemSelected 添加點(diǎn)擊事件滔悉。
代碼如下

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

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        Toast.makeText(this, item.getTitle(), Toast.LENGTH_SHORT).show();
        return super.onOptionsItemSelected(item);
    }

my_menu.xml 如下伊诵,定義在 res/menu 下

<?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/menu_item1"
        android:icon="@drawable/ic_add"
        android:title="添加"
        app:showAsAction="ifRoom" />

    <item
        android:id="@+id/menu_item2"
        android:icon="@drawable/ic_edit"
        android:title="編輯"
        app:showAsAction="ifRoom" />

    <item
        android:id="@+id/menu_item3"
        android:icon="@drawable/ic_delete"
        android:title="刪除"
        app:showAsAction="ifRoom" />

    <item
        android:id="@+id/menu_item4"
        android:icon="@drawable/ic_setting"
        android:title="設(shè)置"
        app:showAsAction="ifRoom" />

    <item
        android:id="@+id/menu_item5"
        android:icon="@drawable/ic_zoom_in"
        android:title="放大"
        app:showAsAction="ifRoom" />

    <item
        android:id="@+id/menu_item6"
        android:icon="@drawable/ic_zoom_out"
        android:title="縮小"
        app:showAsAction="ifRoom" />
</menu>

app:showAsAction="ifRoom" 表示如果空間足夠,就顯示在 Toolbar 上氧敢,如果空間不夠日戈,Toolbar 最右邊就會(huì)顯示三個(gè)點(diǎn)的圖標(biāo)询张,這個(gè)三個(gè)點(diǎn)的圖標(biāo)叫做 Overflow Icon孙乖,溢出按鈕,然后點(diǎn)擊該圖標(biāo)會(huì)出來(lái)一個(gè) Overflow Menu份氧,溢出菜單唯袄,顯示不下的 Item 都會(huì)顯示到這個(gè) Overflow Menu 中。

空間足夠的顯示 Icon 在 Toolbar 上蜗帜×悼剑空間不夠的顯示文字在 Overflow Menu 中。

長(zhǎng)按 Icon 會(huì)以 Toast 的方式把 Title 顯示出來(lái)厅缺,這個(gè) Toast 會(huì)直接顯示在對(duì)應(yīng) Icon 的下方蔬顾。

顯示效果如下

點(diǎn)擊 Overflow Icon 之后顯示的 Overflow Menu 的效果如下

長(zhǎng)按之后顯示的 Toast 如下

Overflow Icon 的顏色可以修改,下面把它修改為白色

    <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>
        <item name="android:textColorSecondary">#ffffff</item>
    </style>

Overflow Menu 的樣式也可以修改

    <style name="MyPopupTheme" parent="ThemeOverlay.AppCompat.Light">
        <item name="android:textColor">@android:color/white</item>
        <item name="android:textSize">12sp</item>
        <item name="android:colorBackground">@android:color/black</item>
        <item name="overlapAnchor">false</item>
    </style>
app:popupTheme="@style/MyPopupTheme"

overlapAnchor 的作用是讓彈出來(lái)的 Overflow Menu 不蓋住 Toolbar湘捎。

效果如下

Overflow Icon 的圖標(biāo)也可以修改

toolbar.setOverflowIcon();

Toolbar 添加 Custom View

Toolbar 其實(shí)是一個(gè) ViewGroup诀豁,也可以自己添加 View 來(lái)達(dá)到想要的效果。

    <android.support.v7.widget.Toolbar
        android:id="@+id/tool_bar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/colorPrimary">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Custom View"
            android:textColor="@android:color/white" />

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

運(yùn)行效果如下

發(fā)現(xiàn)有默認(rèn)的 Title 顯示出來(lái)了窥妇,設(shè)置不顯示即可

getSupportActionBar().setDisplayShowTitleEnabled(false);

效果如下

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末舷胜,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子活翩,更是在濱河造成了極大的恐慌烹骨,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件材泄,死亡現(xiàn)場(chǎng)離奇詭異沮焕,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)拉宗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)遇汞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事空入÷缢” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵歪赢,是天一觀的道長(zhǎng)化戳。 經(jīng)常有香客問(wèn)我,道長(zhǎng)埋凯,這世上最難降的妖魔是什么点楼? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮白对,結(jié)果婚禮上掠廓,老公的妹妹穿的比我還像新娘。我一直安慰自己甩恼,他們只是感情好蟀瞧,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著条摸,像睡著了一般悦污。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上钉蒲,一...
    開(kāi)封第一講書(shū)人閱讀 51,258評(píng)論 1 300
  • 那天切端,我揣著相機(jī)與錄音,去河邊找鬼顷啼。 笑死踏枣,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的钙蒙。 我是一名探鬼主播茵瀑,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼仪搔!你這毒婦竟也來(lái)了瘾婿?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤烤咧,失蹤者是張志新(化名)和其女友劉穎偏陪,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體煮嫌,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡笛谦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了昌阿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饥脑。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡恳邀,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出灶轰,到底是詐尸還是另有隱情谣沸,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布笋颤,位于F島的核電站乳附,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏伴澄。R本人自食惡果不足惜赋除,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望非凌。 院中可真熱鬧举农,春花似錦、人聲如沸敞嗡。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)秸妥。三九已至滚停,卻和暖如春沃粗,著一層夾襖步出監(jiān)牢的瞬間粥惧,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工最盅, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留突雪,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓涡贱,卻偏偏與公主長(zhǎng)得像咏删,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子问词,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

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