动态更新Toolbar Menu以及Menu中同时显示文字和图标

动态更新Toolbar Menu以及Menu中同时显示文字和图标

咱们常常会有这样的需求,在切换Fragment或者点击某个按钮后动态更新Toolbar上Menu项.可是onCreateOptionsMenu方法只在建立Activity的时候调用一次,之后就再也不调用了,因此就不能在onCreateOptionsMenu中作处理了。
不过系统提供了另外的一个方法onPrepareOptionsMenu,咱们能够在这个方法中作一些逻辑处理,而后在须要更新Menu的地方调用invalidateOptionsMenu方法。
效果图以下:
java

点击管理专辑按钮更换Menu,android

@Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu, menu);
        return super.onCreateOptionsMenu(menu);
    }
@Override
    public boolean onPrepareOptionsMenu(Menu menu) {
        if (mIsEditStatus) {
            menu.findItem(R.id.action_share).setVisible(false);
            menu.findItem(R.id.action_edit).setVisible(true);
        } else {
            menu.findItem(R.id.action_share).setVisible(true);
            menu.findItem(R.id.action_edit).setVisible(false);
        }
        return super.onPrepareOptionsMenu(menu);
    }
invalidateOptionsMenu(); //从新绘制menu

另外的一个需求是在Menu中要显示图标和文字,虽然在menu.xml文件中配置了图标和文字,可是在有图标的状况下文字是不会显示的,即便设置 app:showAsAction="always|withText" 可是我在运行的时候发现并无显示文字,处理方法是经过另一个属性实现app:actionLayout.
首先menu.xml定义以下:app

<menu xmlns:android="http://schemas.android.com/apk/res/android"
      xmlns:app="http://schemas.android.com/apk/res-auto"
      xmlns:tools="http://schemas.android.com/tools"
      tools:context=".album.AlbumDetailActivity">

    <item android:id="@+id/action_share"
          android:title="分享"
          android:orderInCategory="80"
          android:icon="@drawable/icon_share_white"
          app:showAsAction="always|withText" />

    <item android:id="@+id/action_edit"
          android:title=""
          android:orderInCategory="60"
          app:showAsAction="always"
          app:actionLayout="@layout/menu_action_album_edit"
        />

</menu>

app:actionLayout指向了一个布局,能够在这个布局中定义你想要的控件。个人定义是这样的。
menu_action_album_edit.xmlide

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"
          android:paddingLeft="10dip"
          android:paddingRight="10dip"
          android:gravity="center"
          android:text="@string/app_edit"
          android:drawableLeft="@drawable/album_edit_white"
          android:textColor="@color/white"
          android:clickable="true" />

android:drawableLeft中指定你的图标。
而后还要在onCreateOptionsMenu中重写一下Menu的点击事件,如今onCreateOptionsMenu方法是这样的:布局

@Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu, menu);
        final MenuItem item = menu.findItem(R.id.action_edit);
        item.getActionView().setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                onOptionsItemSelected(item);
            }
        });

        return super.onCreateOptionsMenu(menu);
    }

而后像普通的Menu item同样在onOptionsItemSelected中处理点击事件就能够了。code

相关文章
相关标签/搜索