toolbar的使用

简介: toolbar的使用

1.创建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/addFriend"
        android:icon="@drawable/addfriend"
        android:orderInCategory="80"
        android:title="添加朋友"
        app:showAsAction="never" />
 
    <item
        android:id="@+id/newChat"
        android:icon="@drawable/morechat"
        android:orderInCategory="90"
        android:title="新建群聊"
        app:showAsAction="never" />
 
    <item
        android:id="@+id/scan"
        android:icon="@drawable/scan"
        android:orderInCategory="100"
        android:title="扫一扫"
        app:showAsAction="never"/>
    <item
        android:id="@+id/money"
        android:icon="@drawable/money"
        android:orderInCategory="100"
        android:title="收付款"
        app:showAsAction="never"/>
 
</menu>

2.activity

布局引入toolbar

        <androidx.appcompat.widget.Toolbar
            android:background="@color/blue"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"
            android:id="@+id/toolbar"/>
setSupportActionBar(mMainBinding.toolbar); 不调用就不会显示toolbar
getSupportActionBar().setTitle("环信 app");  设置toolbar的标题
mMainBinding.toolbar.setOnMenuItemClickListener(listener); 设置监听器
   重写onCreateOptionsMenu 加载menu
@Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.toolbar, menu);
        return true;
    }
    重写onPrepareOptionsPanel 加载menu的图标
@Override
    protected boolean onPrepareOptionsPanel(View view, Menu menu) {
        if (menu != null) {
            if (menu.getClass() == MenuBuilder.class) {
                try {
                    Method m = menu.getClass().getDeclaredMethod("setOptionalIconsVisible", Boolean.TYPE);
                    m.setAccessible(true);
                    m.invoke(menu, true);
                } catch (Exception e) {
                }
            }
        }
        return super.onPrepareOptionsPanel(view, menu);
    }

监听器

    private final Toolbar.OnMenuItemClickListener listener = new Toolbar.OnMenuItemClickListener() {
        @Override
        public boolean onMenuItemClick(MenuItem item) {
            switch (item.getItemId()) {
                case R.id.addFriend:
                    Toast.makeText(MainActivity.this, "addFriend", Toast.LENGTH_SHORT).show();
                    break;
                case R.id.scan:
                    Toast.makeText(MainActivity.this, "scan", Toast.LENGTH_SHORT).show();
                    break;
                case R.id.newChat:
                    Toast.makeText(MainActivity.this, "newChat", Toast.LENGTH_SHORT).show();
                    //弹出自定义popWindow
                    //popUpMyOverflow();
                    break;
                case R.id.money:
                    Toast.makeText(MainActivity.this, "money", Toast.LENGTH_SHORT).show();
                    break;
            }
            return false;
        }
    };


目录
相关文章
|
11月前
|
XML 数据格式
DrawerLayout侧滑菜单、Toolbar和沉浸式状态栏的使用
DrawerLayout侧滑菜单、Toolbar和沉浸式状态栏的使用
在 fragment 中使用 Toolbar 的 menu
在 fragment 中使用 Toolbar 的 menu
|
XML 数据格式
自定义Toolbar的一些小技巧
1、改变Toolbar高度(解决图标不垂直居中) 背景:实际使用中,toolbar默认高度有些大,会挤压内容。想将toolbar高度改小,将layout_height从wrap_content改为固定值。 情况:toolbar的layout_height比默认高度小的时候,发现标题是居中的,但是两侧的图标不垂直居中而偏下了 调查:网上有很多方法,基本都是无效的。甚至有人利用反射直接修改图标的imageview的gravity,非常复杂且右侧图标无法实现。
197 0
|
XML Android开发 数据格式
Toolbar的正确使用姿势
前言 Toolbar是谷歌在2014年Google IO 大会上推出的一套全新的设计规范Material Design。它的出现规范了Android开发者APP标题栏的设计风格,极大地提高了开发效率,而且Material Design设计规范也越来越多出现在我们常用的APP中。
1098 0
|
XML Android开发 数据格式
ActionBar的使用
前言 山水一程,三生有幸。 启用ActionBar ActionBar需要在Android3.0以上的版本才能启用。如果希望关闭ActionBar,则可以设置该应用的主题为Xxxx.NoActionBar,配置如下。
966 0
|
Android开发
[译] 5 分钟让 Drawer 在状态栏下可见
本文讲的是[译] 5 分钟让 Drawer 在状态栏下可见,你也许听过谷歌最新的设计理念 Material Design (“质感设计”)规范,可以让你的抽屉式导航栏跨越整个屏幕,包括状态栏,并且让抽屉后的所有控件以灰暗的网格形式可见。
1129 0