如何在Android中将菜单设置为工具栏

Dr.*_*ody 74 xml android

我想用ToolBar而不是ActionBar,但不要在工具栏中显示我的菜单!我想要设置菜单,如刷新设置按钮ActionBar.

在此输入图像描述

Toolbar.xml代码:

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="?attr/colorPrimary"
    android:minHeight="?attr/actionBarSize"
    app:navigationContentDescription="@string/abc_action_bar_up_description"
    app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
    app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
    app:title="Main Page"
    android:gravity="center"/>
Run Code Online (Sandbox Code Playgroud)

MainPage.java代码:

public class MainPage extends AppCompatActivity {
    private Toolbar toolbar;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main_page);

        toolbar = (Toolbar) findViewById(R.id.main_toolbar);
        setSupportActionBar(toolbar);
        if (getSupportActionBar() != null) {
            getSupportActionBar().setTitle("Main Page");
        }
        toolbar.setSubtitle("Test Subtitle");
        toolbar.inflateMenu(R.menu.main_manu);
    }
}
Run Code Online (Sandbox Code Playgroud)

main_menu.xml代码:

<?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/menu_main_setting"
        android:icon="@drawable/ic_settings"
        android:orderInCategory="100"
        app:showAsAction="always"
        android:actionLayout="@layout/toolbar"
        android:title="Setting" />

    <item
        android:id="@+id/menu_main_setting2"
        android:icon="@drawable/ic_settings"
        android:orderInCategory="200"
        app:showAsAction="always"
        android:actionLayout="@layout/toolbar"
        android:title="Setting" />

</menu>
Run Code Online (Sandbox Code Playgroud)

如何解决此问题并显示菜单Toolbar?谢谢所有亲爱的<3

Key*_*ani 130

只需在MainPage.java中覆盖onCreateOptionsMenu

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main_menu, menu);
    return true;
}
Run Code Online (Sandbox Code Playgroud)


Roh*_*ngh 46

不要使用setSupportActionBar(工具栏)

我不知道为什么但这对我有用.

toolbar = (Toolbar) findViewById(R.id.main_toolbar);
toolbar.setSubtitle("Test Subtitle");
toolbar.inflateMenu(R.menu.main_manu);
Run Code Online (Sandbox Code Playgroud)

对于菜单项,请单击此操作

toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {

        @Override
        public boolean onMenuItemClick(MenuItem item) {

            if(item.getItemId()==R.id.item1)
            {
                // do something
            }
            else if(item.getItemId()== R.id.filter)
            {
               // do something
            }
            else{
               // do something
            }

            return false;
        }
    });
Run Code Online (Sandbox Code Playgroud)

当我找到正确的解释时,会更新此答案的"为什么"部分.
无论如何都乐于助人:)和平.

  • 你回答我的警报,但它没有解释为什么我不应该使用它. (4认同)
  • 您应该解释为什么不使用setSupportActionBar(toolbar)而不是仅仅说什么对您有效。 (3认同)
  • 对我来说,这样做的好处是,我不再需要将我的工具栏绑定到我的单个活动(但有很多很多片段)应用程序中的支持 ActionBar,这需要各种烦人的黑客才能使应用程序看起来和运行良好。 (2认同)

Par*_*ria 42

您需要在Activity中覆盖此代码:

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu, this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main2, menu);
    return true;
}
Run Code Online (Sandbox Code Playgroud)

并设置您的工具栏,如下所示:

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
Run Code Online (Sandbox Code Playgroud)


Sur*_*gch 35

这是一个更全面的答案,作为未来访客的参考.我通常使用支持工具栏,但无论哪种方式都可以.

在此输入图像描述

1.制作菜单xml

这将是res/menu/main_menu.

  • 右键单击该res文件夹并选择" 新建">"Android资源文件".
  • 键入main_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_add"
        android:icon="@drawable/ic_add"
        app:showAsAction="ifRoom"
        android:title="Add">
    </item>
    <item
        android:id="@+id/action_settings"
        app:showAsAction="never"
        android:title="Settings">
    </item>
</menu>
Run Code Online (Sandbox Code Playgroud)

您可以右键单击res并选择" 新建图像资源"以创建ic_add图标.

2.给菜单充气

在您的活动中添加以下方法.

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    MenuInflater inflater = getMenuInflater();
    inflater.inflate(R.menu.main_menu, menu);
    return true;
}
Run Code Online (Sandbox Code Playgroud)

3.处理菜单点击

同样在您的Activity中,添加以下方法:

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle item selection
    switch (item.getItemId()) {
        case R.id.action_add:
            addSomething();
            return true;
        case R.id.action_settings:
            startSettings();
            return true;
        default:
            return super.onOptionsItemSelected(item);
    }
}
Run Code Online (Sandbox Code Playgroud)

进一步阅读

  • 感谢您将所有必要的组件实际显示在一起,而不是仅仅显示两个代码行。 (3认同)

小智 9

第一种方法:在activitymain.xml中

<androidx.appcompat.widget.Toolbar
    android:id="@+id/maintoolbar"
    android:layout_width="match_parent"
    android:layout_height="56dp"/>
Run Code Online (Sandbox Code Playgroud)

在MainActivity.java中

import androidx.appcompat.widget.Toolbar;
private Toolbar toolbar;
Run Code Online (Sandbox Code Playgroud)

onCreate 方法内部 -

 toolbar=findViewById(R.id.maintoolbar);
        setSupportActionBar(toolbar);
Run Code Online (Sandbox Code Playgroud)

在您的 MainActivity 类中 -

   @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.<your menu xml file name here>,menu);
        return super.onCreateOptionsMenu(menu);
    }
Run Code Online (Sandbox Code Playgroud)

第二种方式

 //Remove setSupportActionBar(toolbar) and onCreateOptionmenu.
 toolbar=findViewById(R.id.maintoolbar);
 toolbar.inflateMenu(R.menu.<your menu xml file name here>);
Run Code Online (Sandbox Code Playgroud)


hat*_*ata 7

没有 ActionBar 但有 Toolbar

如果您想使用 Toolbar 而不是 ActionBar,则setSupportActionBar原则上是矛盾的,正如 @RohitSingh上面回答的那样。

您既不需要使用setSupportActionBar也不需要覆盖用于 ActionBar 的onCreateOptionsMenu和。onOptionsItemSelected

  1. NoActionBar主题
  2. 将工具栏放置在布局 xml 中
  3. 准备菜单 xml
  4. Toolbar#inflateMenu(或者你也可以在布局xml中设置菜单)
  5. Toolbar#setOnMenuItemClickListener

下面是一个例子。

1.NoActionBar主题

MaterialCompolent.DayNight本示例中使用主题)

<style name="Theme.AppTheme" parent="Theme.MaterialComponents.DayNight.NoActionBar">
Run Code Online (Sandbox Code Playgroud)

2. 在布局中放置工具栏

MaterialToobar本示例中使用)

<androidx.constraintlayout.widget.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.google.android.material.appbar.MaterialToolbar
        android:id="@+id/toolbar"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
Run Code Online (Sandbox Code Playgroud)

3.准备菜单xml

<menu xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:id="@+id/item1"
        android:title="@string/item1"
        app:showAsAction="ifRoom" />
    <item
        android:id="@+id/item2"
        android:title="@string/item2"
        app:showAsAction="ifRoom" />
</menu>
Run Code Online (Sandbox Code Playgroud)

4. 工具栏#inflateMenu

binding.toolbar.inflateMenu(R.menu.main); // binding is a ViewBinding
Run Code Online (Sandbox Code Playgroud)

5. 工具栏#setOnMenuItemClickListener

最近的 Android 建议避免使用switch来区分 id。使用普通if ~ else if ~ else块是理想的。除此之外,我们还可以在 Java 8 中使用lambda 。

binding.toolbar.setOnMenuItemClickListener(menuItem -> {
    int itemId = menuItem.getItemId();
    if (itemId == R.id.item1) {
        // do something for item1
        return true;
    } else if (itemId == R.id.item2) {
        // do something for item2
        return true;
    } else {
        // if you do nothing, returning false should be appropriate.
        return false;
    }
});
Run Code Online (Sandbox Code Playgroud)


Lil*_*a J 6

您还需要此功能,以便对菜单的每个选项执行一些操作。

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
        case R.id.menu_help:
            Toast.makeText(this, "This is teh option help", Toast.LENGTH_LONG).show();
            break;
        default:
            break;
    }
    return true;
}
Run Code Online (Sandbox Code Playgroud)


Moh*_*had 5

即使在使用 setSupportActionBar(toolbar) 时,您仍然可以使用 Toolbar.inflateMenu 提供答案

我有一个场景,我必须将工具栏设置功能移到活动之外的单独类中,而活动本身并不知道 onCreateOptionsMenu 事件。

所以,为了实现这一点,我所要做的就是在调用 inflateMenu 之前等待 Toolbar 被绘制,执行以下操作:

toolbar.post {
    toolbar.inflateMenu(R.menu.my_menu)
}
Run Code Online (Sandbox Code Playgroud)

可能不会被认为很干净,但仍然可以完成工作。