Toolbar

作者: AndroidNotes | 来源:发表于2019-03-25 16:04 被阅读0次

    ActionBar

    Android 3.0之后,Google引入了ActionBar,想统一安卓应用的导航栏样式。但由于ActionBar难以定制,很大程度上限制了开发人员,比如标题文字大小、间距等不易实现个性化,很多开发者放弃了ActionBar的使用,而是使用普通的ViewGroup来封装自己的App Bar,或者使用JakeWharton大神ActionBarSherlock库。

    ToolBar

    后来,自2014年Google I/O 上Material Design横空出世后,市场上的应用又逐步趋向了样式的风格统一,support library中很快就出来了Toolbar控件,一个定制化的ViewGroup,来完善ActionBar的使用。

    ToolBar的基本使用

    ToolBar的主题
    1. 方法一
    <style name="AppTheme.Base" parent="Theme.AppCompat">
        <item name="windowActionBar">false</item>
        <item name="android:windowNoTitle">true</item>
        ......
    </style>
    
    1. 方法二
    <style name="AppTheme.Base" parent="heme.AppCompat.Light.NoActionBar">
        ......
    </style>
    
    如何使用ToolBar
    1. 添加依赖
        implementation 'com.android.support:appcompat-v7:28.0.0'
    
    1. xml布局中添加控件
    <!--   navigationIcon  左边返回箭头图标
           navigationContentDescription 目前还不知道其作用
           titleMarginStart  标题距离(开始)左边的距离
           -->
    <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="@color/colorAccent"
            app:navigationIcon="@drawable/ic_back_white_24dp"
            app:title="标题"
            app:titleTextColor="@color/white">
     </android.support.v7.widget.Toolbar>
    

    也可以在代码中设置标题等

     Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
            toolbar.setTitle("标题");
            toolbar.setTitleTextColor(Color.WHITE);
            toolbar.setNavigationIcon(R.drawable.ic_back_white_24dp);
    
            //点击左边返回按钮监听事件
            toolbar.setNavigationOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
    
                }
            });
    
    1. 在Activity中使用
    Toolbar mToolbarTb = (Toolbar) findViewById(R.id.tb_toolbar);
    setSupportActionBar(mToolbarTb);
    

    Options Menu

    1. 在res下新建menu的文件夹,并新建文件xxx.xml
    <?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_add"
            android:icon="@drawable/android"
            android:orderInCategory="100"
            android:title="Add"
            app:showAsAction="always"/>
    </menu>
    
    
    1. 在Activity中重写menu的两个方法
        override fun onCreateOptionsMenu(menu: Menu): Boolean {
            menuInflater.inflate(com.mvlin.wmeeting.lxd.R.menu.menu_action, menu)
            return super.onCreateOptionsMenu(menu)
        }
    
        override fun onOptionsItemSelected(item: MenuItem): Boolean {
            when (item.itemId) {
                R.id.action_add -> {ToastUtils.showShort("新增一条")}
            }
            return super.onOptionsItemSelected(item)
        }
    

    标题居中

        <android.support.v7.widget.Toolbar
            android:id="@+id/tb_toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="@color/gray"
            app:title="">
    
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"//标题居中
                android:gravity="center"
                android:text="@string/todolist"
                android:textSize="20sp"/>
        </android.support.v7.widget.Toolbar>
    

    修改ToolBar的主题

    ToolBar主题

    如图,溢出按钮的颜色是黑色,那么怎么修改成与主题色搭配的白色呢?可以通过修改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中的tool_bar_pop_theme属性设置Menu Item的字体颜色,如:

        <style name="tool_bar_pop_theme" parent="Theme.AppCompat.Light.NoActionBar">
            <!-- 设置Menu菜单的背景色 -->
            <item name="android:itemBackground">@android:color/white</item>
            <!-- 设置Menu菜单的字体颜色 -->
            <item name="android:textColorPrimary">@android:color/black</item>
            <!-- 设置Menu窗口不覆盖Toolbar视图 -->
            <item name="overlapAnchor">false</item>
        </style>
    

    将style设置给ToolBar

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

    相关文章

      网友评论

          本文标题:Toolbar

          本文链接:https://www.haomeiwen.com/subject/fyfbvqtx.html