Material Design整理(三)——ToolBar

来源:互联网 发布:域名怎么和空间绑定 编辑:程序博客网 时间:2024/05/18 02:41

github地址 点击打开

简介

应用内容的标准工具栏,可以说是ActionBar的升级版,两者不是独立关系。

  • 应用内容的标准工具栏,可以说是ActionBar的升级版,两者不是独立关系。
  • 相比ActionBar,ToolBar更加自由,可以随意放置,当一个ViewGroup来使用。
  • ToolBar提供了可定制、修改的属性:

     - 导航栏图标 - AppLogo - 主标题、子标题 - 添加一个或多个自定义控件 - 支持Action Menu 等

使用

1、在res/menu文件夹下,创建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/action_search"        android:icon="@mipmap/ic_search"        android:title="搜索"        app:showAsAction="ifRoom" />    <!--右侧添加操作条目-->    <item        android:id="@+id/action_add"        android:icon="@mipmap/ic_add"        android:title="添加"        app:showAsAction="ifRoom" />    <!--右侧设置条目,收起,不显示-->    <item        android:id="@+id/action_setting"        android:icon="@mipmap/ic_settings"        android:title="设置"        app:showAsAction="never" />    <!--右侧设置帮助条目,收起,不显示-->    <item        android:id="@+id/action_help"        android:icon="@mipmap/ic_help"        android:title="帮助"        app:showAsAction="never" /></menu>

其中showAsAction可选参数为:

  • always:使菜单项一直显示在ToolBar上
  • ifRoom:如果有足够的空间,菜单项显示在ToolBar上,否则显示在更多中
  • never:菜单项永远不显示在ToolBar上,只显示在更多中
  • withText:图标和文字一起显示

2、在布局中使用ToolBar

<android.support.v7.widget.Toolbar    android:id="@+id/toolbar"    android:layout_width="match_parent"    android:layout_height="?attr/actionBarSize"    android:background="?attr/colorPrimary"    app:popupTheme="@style/AppTheme.PopupOverlay" />

另外:可以把ToolBar当做普通ViewGroup来使用,所以可以在布局文件中直接将自定义控件放置其中

3、在Activity中

在setContentView方法之前,设置界面没有标题栏:

  • 如果Activity继承Activity,设置:
requestWindowFeature(Window.FEATURE_NO_TITLE);
  • 如果Activity继承的是AppCompatActivity,则:
supportRequestWindowFeature(Window.FEATURE_NO_TITLE);

附:隐藏导航栏有两种方法:

  • 如上在代码中设置
  • 在清单文件中给对应Activity设置主题,主题为Theme.AppCompat.Light.NoActionBar

4、将ToolBar作为导航栏

setSupportActionBar(toolbar);

5、可以对ToolBar进行其他设置

//设置App图标toolbar.setLogo(R.mipmap.ic_launcher);//设置导航的图标toolbar.setNavigationIcon(R.mipmap.ic_menu);// 设置主标题toolbar.setTitle("J++");// 设置子标题toolbar.setSubtitle("MaterialDesign");

6、添加菜单项

@Overridepublic boolean onCreateOptionsMenu(Menu menu) {    getMenuInflater().inflate(R.menu.menu_toolbar_main, menu);    return true;}

此步骤就是将创建的menu文件设置给ToolBar

7、对菜单项添加点击事件

@Overridepublic boolean onOptionsItemSelected(MenuItem item) {    switch (item.getItemId()) {        case R.id.action_search:            Snackbar.make(toolbar, "搜索", Snackbar.LENGTH_LONG).show();            break;        case R.id.action_add:            Snackbar.make(toolbar, "更多", Snackbar.LENGTH_LONG).show();            break;        case R.id.action_setting:            Snackbar.make(toolbar, "设置", Snackbar.LENGTH_LONG).show();            break;        case R.id.action_help:            Snackbar.make(toolbar, "帮助", Snackbar.LENGTH_LONG).show();            break;    }    return false;}

还有另外一种方式:

setOnMenuItemClickListener(new ToolBar.OnMenuItemClickListener());

8、当然,还有导航图标的点击

toolbar.setNavigationOnClickListener(new View.OnClickListener() {    @Override    public void onClick(View view) {        drawer.openDrawer(Gravity.LEFT);    }});
原创粉丝点击