Android導(dǎo)航控件之Toolbar

簡介

Toolbar是在 Android 5.0 開始推出的一個 Material Design 風(fēng)格的導(dǎo)航控件 用來取代之前的 Actionbar

Toolbar支持:

  • 設(shè)置導(dǎo)航欄圖標(biāo)
  • 設(shè)置App的logo
  • 支持設(shè)置標(biāo)題和子標(biāo)題
  • 支持添加一個或多個的自定義控件
  • 支持Action Menu

實踐說明

默認(rèn)情況下Activity是有一個ActionBar的

如何刪除這個ActionBar呢碰声?

首先在styles文件中自定義一個style

    <style name="MyTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

然后在對應(yīng)Activity清單文件中配置

  <activity
         android:name=".FirstToolbarActivity"
         android:theme="@style/MyTheme"/>

第一種樣式

布局文件


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    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:navigationIcon="@mipmap/ic_book_list"
        app:titleTextColor="@color/white"
        app:theme="@style/CustomToolbarTheme">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:layout_gravity="center"
            android:text="標(biāo)題"
            android:textColor="@android:color/white"
            android:textSize="16sp"/>

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

</RelativeLayout>

FirstToolbarActivity.java

package com.zhoujian.toolbar;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;

/**
 * Created by zhoujian on 2017/3/8.
 */

public class FirstToolbarActivity extends AppCompatActivity {

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

    private void initView()
    {

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

        // 設(shè)置navigation button 點擊事件
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                finish();
            }
        });

        //設(shè)置menu
        toolbar.inflateMenu(R.menu.menu_item);
        // 設(shè)置溢出菜單的圖標(biāo)
        toolbar.setOverflowIcon(getResources().getDrawable(R.mipmap.icon_menu));
        // 設(shè)置menu item 點擊事件
        toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(MenuItem item) {
                switch (item.getItemId()){
                    case R.id.item_collect:
                        //點擊設(shè)置
                        Toast.makeText(FirstToolbarActivity.this, "按鈕被點擊了", Toast.LENGTH_SHORT).show();
                        break;

                    case R.id.item_talk:
                        //點擊設(shè)置
                        Toast.makeText(FirstToolbarActivity.this, "發(fā)起群聊點擊了", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.item_add:
                        //點擊設(shè)置
                        Toast.makeText(FirstToolbarActivity.this, "添加朋友被點擊了", Toast.LENGTH_SHORT).show();
                        break;

                }
                return false;
            }
        });

    }
}

顯示效果:

a.png

第二種樣式

布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:toolbar="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"
        toolbar:logo="@mipmap/ic_launcher"
        toolbar:navigationIcon="@mipmap/ic_book_list"
        toolbar:subtitle="小標(biāo)題"
        toolbar:theme="@style/CustomToolbarTheme"
        toolbar:title="大標(biāo)題"
        toolbar:titleMarginStart="20dp"
        toolbar:titleTextColor="@color/white">


        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="50dp"
            android:text="我的"
            android:textColor="@color/white"
            android:textSize="14sp"/>
        
    </android.support.v7.widget.Toolbar>
    
</RelativeLayout>

SecondToolbarActivity.java

package com.zhoujian.toolbar;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;

/**
 * Created by zhoujian on 2017/3/8.
 */

public class SecondToolbarActivity extends AppCompatActivity {

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

    private void initView()
    {

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

        // 設(shè)置navigation button 點擊事件
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                finish();
            }
        });


        //設(shè)置menu
        toolbar.inflateMenu(R.menu.menu_item);
        // 設(shè)置溢出菜單的圖標(biāo)
        toolbar.setOverflowIcon(getResources().getDrawable(R.mipmap.icon_menu));
        // 設(shè)置menu item 點擊事件
        toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(MenuItem item) {
                switch (item.getItemId()){
                    case R.id.item_collect:
                        //點擊設(shè)置
                        Toast.makeText(SecondToolbarActivity.this, "按鈕被點擊了", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.item_talk:
                        //點擊設(shè)置
                        Toast.makeText(SecondToolbarActivity.this, "發(fā)起群聊點擊了", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.item_add:
                        //點擊設(shè)置
                        Toast.makeText(SecondToolbarActivity.this, "添加朋友被點擊了", Toast.LENGTH_SHORT).show();
                        break;
                }
                return false;
            }
        });

    }
}

顯示效果:

b.png

第三種樣式

布局文件


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:toolbar="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"
        toolbar:title="使用實例"
        toolbar:navigationIcon="@mipmap/ic_book_list"
        toolbar:titleTextColor="@color/white"
        toolbar:theme="@style/CustomToolbarTheme">
        
    </android.support.v7.widget.Toolbar>
</RelativeLayout>

ThirdToolbarActivity.java

package com.zhoujian.toolbar;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;

/**
 * Created by zhoujian on 2017/3/8.
 */

public class ThirdToolbarActivity extends AppCompatActivity {

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

    private void initView()
    {

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

        // 設(shè)置navigation button 點擊事件
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                finish();
            }
        });


        //設(shè)置 Toolbar menu
        toolbar.inflateMenu(R.menu.toolbar_menu);
        // 設(shè)置溢出菜單的圖標(biāo)
        toolbar.setOverflowIcon(getResources().getDrawable(R.mipmap.icon_menu));
        // 設(shè)置menu item 點擊事件
        toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(MenuItem item) {
                switch (item.getItemId()){
                    case R.id.publish:
                        //點擊設(shè)置
                        Toast.makeText(ThirdToolbarActivity.this, "發(fā)布按鈕被點擊了", Toast.LENGTH_SHORT).show();
                        break;


                }
                return false;
            }
        });

    }
}


顯示效果:

c.png

第四種樣式

布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:toolbar="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"
        toolbar:navigationIcon="@mipmap/ic_book_list"
        toolbar:theme="@style/CustomToolbarTheme"
        toolbar:titleTextColor="@color/white">

        <EditText
            android:id="@+id/edit_search"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:textColor="@color/white"/>

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

FourthToolbarActivity.java


package com.zhoujian.toolbar;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;

/**
 * Created by zhoujian on 2017/3/8.
 */

public class FourthToolbarActivity extends AppCompatActivity {

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

    private void initView()
    {

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

        // 設(shè)置navigation button點擊事件
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                finish();
            }
        });


        //設(shè)置menu
        toolbar.inflateMenu(R.menu.menu_search);
        // 設(shè)置溢出菜單的圖標(biāo)
        toolbar.setOverflowIcon(getResources().getDrawable(R.mipmap.icon_menu));
        // 設(shè)置menu item 點擊事件
        toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(MenuItem item) {
                switch (item.getItemId()){
                    case R.id.item_search:
                        //點擊設(shè)置
                        Toast.makeText(FourthToolbarActivity.this, "搜索按鈕被點擊了", Toast.LENGTH_SHORT).show();
                        break;

                }
                return false;
            }
        });

    }
}

顯示效果:

d.png

源碼下載

源碼下載:https://github.com/zeke123/Toolbar

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市冗疮,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌诅挑,老刑警劉巖拔妥,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件铺厨,死亡現(xiàn)場離奇詭異解滓,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)逸邦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進(jìn)店門雷客,熙熙樓的掌柜王于貴愁眉苦臉地迎上來搅裙,“玉大人部逮,你說我怎么就攤上這事掐禁「凳拢” “怎么了蹭越?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵驾霜,是天一觀的道長。 經(jīng)常有香客問我猜旬,道長洒擦,這世上最難降的妖魔是什么熟嫩? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任柠逞,我火速辦了婚禮板壮,結(jié)果婚禮上绰精,老公的妹妹穿的比我還像新娘卿樱。我一直安慰自己繁调,他們只是感情好涉馁,可當(dāng)我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著妻往,像睡著了一般讯泣。 火紅的嫁衣襯著肌膚如雪好渠。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天,我揣著相機(jī)與錄音杆烁,去河邊找鬼兔魂。 笑死拍棕,一個胖子當(dāng)著我的面吹牛绰播,可吹牛的內(nèi)容都是我干的链蕊。 我是一名探鬼主播滔韵,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼宴卖!你這毒婦竟也來了随闽?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎栏赴,沒想到半個月后靖秩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體须眷,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年沟突,在試婚紗的時候發(fā)現(xiàn)自己被綠了花颗。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡扩劝,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出职辅,到底是詐尸還是另有隱情棒呛,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布域携,位于F島的核電站簇秒,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏秀鞭。R本人自食惡果不足惜趋观,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望锋边。 院中可真熱鬧皱坛,春花似錦、人聲如沸豆巨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至抹沪,卻和暖如春刻肄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背融欧。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工敏弃, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人噪馏。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓麦到,卻偏偏與公主長得像,于是被迫代替她去往敵國和親欠肾。 傳聞我的和親對象是個殘疾皇子瓶颠,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,627評論 2 350

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