【Android - V】之Toolbar的使用

来源:互联网 发布:淘宝推广认准晨昊网络 编辑:程序博客网 时间:2024/06/04 17:58

Toolbar是Android V7包中的一个控件,用来代替Action Bar作为界面的头部标题栏布局。Toolbar相对于Action Bar的特点是更加灵活,可以显示在任何位置。

首先先来看Toolbar在布局文件中的代码怎么写,实际上跟其他Android原生控件一样,只需要设置宽高、背景等属性就可以了,如果有其他需求还可以设置theme等主题属性。

下面是一个Toolbar在布局文件中的代码:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:app="http://schemas.android.com/apk/res-auto"    android:id="@+id/activity_main"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:background="#FFFFFFFF">    <android.support.v7.widget.Toolbar        android:id="@+id/toolbar"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:background="@color/colorPrimary"        android:minHeight="?attr/actionBarSize"        app:popupTheme="@style/ThemeOverlay.AppCompat.Light"        app:theme="@style/ThemeOverlay.AppCompat.ActionBar" /></RelativeLayout>
在布局文件中写了Toolbar之后运行,Toolbar只是显示为一个有背景的长条,上面没有任何东西,这是因为我们没有将Toolbar和Activity进行绑定。我们在Activity中调用setSupportActionBar()方法就可以将Toolbar和Activity进行绑定了。代码如下:

        // 使Toolbar取代原来的ActionBar        setSupportActionBar(toolbar);

Toolbar中可以放很多控件,看下面这张图,一目了然。


这里列出一些为Toolbar设置属性的代码:

        // 设置Toolbar中的各个控件        toolbar.setLogo(R.mipmap.ic_launcher);        toolbar.setTitle("Toolbar title");        toolbar.setTitleTextColor(Color.RED);        toolbar.setSubtitle("Toolbar Subtitle");        toolbar.setSubtitleTextColor(Color.YELLOW);        toolbar.setNavigationIcon(android.R.drawable.ic_menu_camera);

通过红色字的提示来设置,就可以绘制出不同的控件到Toolbar中。值得一说的是最右侧的三个图标,这三个图标实际上都是来自与一个menu文件,即这三个按钮属于同一个menu,设置了showAsAction属性为ifRoom的Item可以像途中的前两项一样,如果有足够的空间就可以显示出来;而设置了showAsAcion属性为never的Item就存放在最右边的项中,点击这一项可以弹出一个下拉列表展示其余项。menu文件中的内容如下:

<menu xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:app="http://schemas.android.com/apk/res-auto">    <item        android:id="@+id/action_edit"        android:icon="@android:drawable/ic_menu_edit"        android:orderInCategory="80"        android:title="编辑"        app:showAsAction="ifRoom" />    <item        android:id="@+id/action_share"        android:icon="@android:drawable/ic_menu_share"        android:orderInCategory="90"        android:title="分享"        app:showAsAction="ifRoom" />    <item        android:id="@+id/action_settings"        android:orderInCategory="100"        android:title="设置"        app:showAsAction="never" /></menu>
此处还需要注明一点,如果不给Activity绑定menu,Toolbar中就不会显示菜单按钮,就算最右边的三个点的图案也不会显示,只有在设置了menu之后才会显示。

Toolbar还会和DrawerLayout、CoordinatorLayout等控件结合使用,这里给大家一些传送门,供大家参考:

  • Toolbar和DrawerLayout结合使用
  • Toolbar和CoordinatorLayout结合使用


以上就是对Toolbar的简单使用的介绍,下面贴出码云上的源码,供大家参考:

DEMO地址

0 0
原创粉丝点击