Material Design整理(三)——ToolBar

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、添加菜单项

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.menu_toolbar_main, menu);
    return true;
}
此步骤就是将创建的menu文件设置给ToolBar

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

@Override
public 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);
    }
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值