工具栏导航图标从未设置


67

我正在尝试使用新的工具栏组件,但导航图标遇到了一些麻烦。我想为后退导航实现一个自定义图标:

在清单中,我为自己的活动设置了父母:

<activity android:name=".CardsActivity" android:parentActivityName=".MainActivity">
    <!-- Parent activity meta-data to support API level 7+ -->
    <meta-data
        android:name="android.support.PARENT_ACTIVITY"
        android:value=".MainActivity" />
</activity>

我这样声明工具栏:

<RelativeLayout 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:paddingBottom="@dimen/activity_vertical_margin"
    tools:context="com.example.lollitest.MainActivity" >
    
    <android.support.v7.widget.Toolbar
        android:id="@+id/my_awesome_toolbar"
        android:layout_height="wrap_content"
        android:layout_width="match_parent"
        android:minHeight="?attr/actionBarSize"
        android:layout_marginBottom="10dp"
        android:background="?attr/colorPrimary" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/my_awesome_toolbar"
        android:text="@string/hello_world" />

</RelativeLayout>

然后在我的活动中,像这样配置工具栏:

Toolbar toolbar = (Toolbar) findViewById(R.id.my_awesome_toolbar);
toolbar.setNavigationIcon(R.drawable.ic_good);
toolbar.setTitle("Title");
toolbar.setSubtitle("Sub");
toolbar.setLogo(R.drawable.ic_launcher);
setSupportActionBar(toolbar);

给我的: 带后退按钮的工具栏

后图标不是我设置的图标setNavigationIcon()!无论我给该方法绘制什么内容,导航图标始终是后退箭头。

我试图删除清单中的父关联,但唯一的效果是(显然)是为了防止按钮返回。

相反,如果我想要默认的后退箭头图标并且不打电话,setNavigationIcon()我根本没有任何图标。

处理工具栏中的导航图标(自定义和默认)的正确方法是什么?

注意:我正在Android 4.4上运行测试


香港专业教育学院做了很多次,现在不知何故对我不起作用?
filthy_wizard

Answers:


115

目前您可以使用它,更改顺序:(这似乎是一个错误)

Toolbar toolbar = (Toolbar) findViewById(R.id.my_awesome_toolbar);
setSupportActionBar(toolbar);

toolbar.setNavigationIcon(R.drawable.ic_good);
toolbar.setTitle("Title");
toolbar.setSubtitle("Sub");
toolbar.setLogo(R.drawable.ic_launcher);

1
确实,该功能适用​​于自定义图标!如果要使用默认图标,那又没有什么等效于sethomebuttonenabled(true)呢?
grunk

4
getSupportedActionBar()。setHomeButtonEnabled(true);
加布里埃里奥·马里奥蒂

10
@GabrieleMariotti只是纠正!getSupportActionBar()。setHomeButtonEnabled(true);
shaktiman_droid 2014年

@Jabbar_Jigariyo这似乎不适用于我。是否还有用于设置“主页”按钮的特定订购错误?
cnfw 2014年

13
没关系,我找到了解决方法。您必须在getSupportActionBar().setDisplayHomeAsUpEnabled(true);setSupportActionBar之后添加到工具栏。类似于设置导航图标。
cnfw 2014年

23

特定于导航图标,这是正确的顺序

// get the actionbar as Toolbar and set it up
Toolbar toolbar = (Toolbar) findViewById(R.id.signIn_toolbar);
setSupportActionBar(toolbar);

通知工具栏以提供向后导航。这会将图标设置为默认的材质图标

getSupportActionBar().setDisplayHomeAsUpEnabled(true);

稍后使用自定义图标覆盖该图标,在我的情况下为Holo后盖图标

toolbar.setNavigationIcon(R.drawable.ic_chevron_left_white_36dp);

20

(对user802421的回答)

private void setToolbar() {
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    if (toolbar != null) {
        setSupportActionBar(toolbar);
        toolbar.setNavigationIcon(R.drawable.ic_action_back);
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                onBackPressed();
            }
        });
    }
}

工具栏

<android.support.v7.widget.Toolbar
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="@dimen/toolbar_height"
    android:background="?attr/colorPrimaryDark" />

7

使用setNavigationIcon进行更改。不要忘记先创建ActionBarDrawerToggle!

示例代码对我有用:

    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);


    drawer = (DrawerLayout)findViewById(R.id.drawer_layout);

    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
            this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
    drawer.setDrawerListener(toggle);

    toggle.syncState();

    toolbar.setNavigationIcon(R.drawable.ic_menu);

这对我有用-终于!更改标准burgermenu图标的工作非常困难。我想不通为什么在设置完所有其他设置然后分配图标后仍然可以正常工作-有人知道吗?
ZooMagic

4

我刚刚找到了解决方案。真的很简单:

mDrawerToggle.setDrawerIndicatorEnabled(false);

希望对您有帮助。


1
请说,如何得到mDrawerToggle物体!
Adrian Preuss

android.support.v7.widget.Toolbar没有setDrawerIndicatorEnabled方法
Miguel Beltran,

@AdrianPreuss您应该自己创建它。示例:ActionBarDrawerToggle(activity, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close)
Android开发人员

3

我有类似的问题。经过一番头痛之后,我发现我的ActionBarDrawerToggle也在修改图标,也不应修改图标(因为我没有将工具栏引用到切换组件)。所以在我的NavigationDrawerFragment类(即拉手的开启和关闭)的setUp(...)方法我一套
mDrawerToggle.setHomeAsUpIndicator(R.drawable.app_icon);
,最后它的工作。


3

我尝试设置像@Gabriele Mariotti这样的工具栏,但是标题有些问题。所以我将命令设置为

toolbar.setTitle("Title")
setSupportActionBar(toolbar);
toolbar.setNavigationIcon(R.drawable.ic_good);

而且有效。


3

我用下面的方法,实际上是上面所有方法的难题。我还发现onOptionsItemSelected从未激活。

    mDrawerToggle.setDrawerIndicatorEnabled(false);
    getSupportActionBar().setHomeButtonEnabled(true);

    Toolbar toolbar = (Toolbar) findViewById(R.id.tool_bar);
    if (toolbar != null) {
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                onBackPressed();
            }
        });
    }

3

您可以invalidate()在任何地方使用方法更改工具栏状态。例:

Toolbar toolbar = (Toolbar)findViewById(R.id.my_awesome_toolbar);
setSupportActionBar(toolbar);

toolbar.setNavigationIcon(R.mipmap.arrow_white);
toolbar.invalidate();       // restore toolbar

3

如果已添加,请从活动中删除此行

 @Override
    protected void onPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);
        // Sync the toggle state after onRestoreInstanceState has occurred.
        mDrawerToggle.syncState();
    }

然后设置图标

 getSupportActionBar().setHomeAsUpIndicator(icon);

1

为我工作...

<android.support.v7.widget.Toolbar
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/toolBar"
        android:background="@color/colorGreen"
        app:title="Title"
        app:titleTextColor="@color/colorBlack"
        app:navigationIcon="@drawable/ic_action_back"/>

1

如果您不想将工具栏设置为操作栏,则可以使用以下方法:

        val toggle = ActionBarDrawerToggle(this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close)
        toggle.isDrawerSlideAnimationEnabled = false
        toggle.isDrawerIndicatorEnabled = false
        toggle.setHomeAsUpIndicator(AppCompatResources.getDrawable(this, ...))
        drawer!!.addDrawerListener(toggle)
        toggle.setToolbarNavigationClickListener {
            setDrawerOpened(!isDrawerOpened())
        }
        toggle.syncState()

fun setDrawerOpened(open: Boolean) {
    if (open == drawerLayout.isDrawerOpen(GravityCompat.START))
        return
    if (open)
        drawerLayout.openDrawer(GravityCompat.START)
    else drawerLayout.closeDrawer(GravityCompat.START)
}

在尝试了许多不同的选择之后,此解决方案为我工作。而且我相信此选项toggle.isDrawerIndicatorEnabled = false对于确保可以设置新图标至关重要。
阿尼尔·戈尔西(Annil Gorthy),

-1

尝试这个:

  <android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:toolbar="http://schemas.android.com/apk/res-auto"
        android:id="@+id/tool_drawer"
        android:layout_width="match_parent"
        android:layout_height="?actionBarSize"
        toolbar:navigationIcon="@drawable/ic_navigation">

    </android.support.v7.widget.Toolbar>
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.