安卓棒棒糖,如何在工具栏标题处添加弹出菜单

47

我不知道如何像许多 Material Design 示例中所展示的那样从标题添加弹出菜单。希望能得到帮助。

从标题弹出工具栏


我认为它可能是setMenu,但我还没有在文档中看到它。我正在查看的文档链接是:http://developer.android.com/reference/android/support/v7/widget/Toolbar.html,(附图链接: http://cl.ly/image/303N3G0o1z1V)。 - Matt Wear
2个回答

97

你需要在工具栏中添加一个Spinner:

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

    <Spinner
            android:id="@+id/spinner_nav"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

</android.support.v7.widget.Toolbar>

然后您需要禁用默认标题:

Toolbar toolbar = findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayShowTitleEnabled(false);

然后您可以根据需要在Activity/Fragment中检索并设置Spinner。


1
你能否看一下我的问题:https://dev59.com/2l8d5IYBdhLWcg3wgiT4? - Damian Petla
4
我们能把下拉菜单放在工具栏的右侧吗?以及如何设置下拉菜单的默认文本/值? - Khairil Ushan
1
我还在工具栏中添加了旋转器,但是下拉菜单项是深色的,而溢出菜单是白色的。 - bajicdusko
5
在使用SpinnerAdapter.createFromResource(context, ...)时,你需要使用getSupportActionBar().getThemedContext()。这样可以使内容更加通俗易懂,但不改变原来的意思。 - ljbade
1
不,你必须使用支持库来提供兼容性。 - Robert Estivill
显示剩余4条评论

1
我在寻找防止弹出窗口覆盖旋转图标的解决方案时遇到了这个问题,我想在这里留下一个替代性解决方案,即使用menu.xml将旋转图标添加到工具栏中。

activity_main.xml

<LinearLayout 
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">

<android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:fitsSystemWindows="true">

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="?attr/colorAccent" />

</android.support.design.widget.AppBarLayout>

 <!-- Other layout widgets -->

</LinearLayout>

menu_main.xml

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

<item
    android:id="@+id/spinner"
    android:title="Spinning"
    app:actionViewClass="android.widget.Spinner"
    app:showAsAction="always" />

<!-- Other items -->

</menu>

您的活动

需要重写 onCreateOptionMenu() 方法,然后使用 getMenuInflater() 来填充之前创建的菜单文件。

您还需要获取 Spinner 项目并像通常一样设置适配器。

   @Override
public boolean onCreateOptionsMenu(Menu menu) {

    getMenuInflater().inflate(R.menu.menu_main, menu);

    //Get Spinner item from menu

    MenuItem spinnerMenuItem = menu.findItem(R.id.spinner);
    final Spinner spinner = (Spinner) MenuItemCompat.getActionView(spinnerMenuItem);

    //Set adapter whichever way you prefer (from the resource or manually)

    final ArrayAdapter<CharSequence> spinnerAdapter = ArrayAdapter
            .createFromResource(this, R.array.items_array, android.R.layout.simple_spinner_dropdown_item);
    spinnerAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
    spinner.setAdapter(spinnerAdapter);

    return true;

}

Style.xml

最后,如果您想自定义您的旋转器。
<resources>

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <item name="android:spinnerStyle">@style/spinner_style</item>
</style>

<style name="spinner_style" parent="Widget.AppCompat.Spinner">
    <item name="android:dropDownVerticalOffset">40dip</item>
    <!--<item name="android:dropDownHorizontalOffset">0dip</item>-->
    <item name="overlapAnchor">false</item>

    <!--Other customizations-->

</style>


有没有办法用定义为菜单项的下拉框替换工具栏中的标题? - Sebastien

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接