Android 从未设置工具栏导航图标
我正在尝试新的工具栏组件,但导航图标出现了一些问题。 我想为后向导航实现一个自定义图标: 在我的清单中,我为我的活动设置了父项:Android 从未设置工具栏导航图标,android,material-design,android-toolbar,android-appcompat,android-actionbar-compat,Android,Material Design,Android Toolbar,Android Appcompat,Android Actionbar Compat,我正在尝试新的工具栏组件,但导航图标出现了一些问题。 我想为后向导航实现一个自定义图标: 在我的清单中,我为我的活动设置了父项: <activity android:name=".CardsActivity" android:parentActivityName=".MainActivity"> <!-- Parent activity meta-data to support API level 7+ --> &l
<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>
这给了我:
后退图标不是我用setNavigationIcon()
设置的图标!无论我给这个方法画的是什么,导航图标总是后面的箭头
我试图删除清单中的父关联,但唯一的效果(显然)是阻止按钮返回
相反,如果我想要默认的返回箭头图标并且不调用setNavigationIcon()
我根本没有任何图标
如何正确处理工具栏中的导航图标(自定义和默认)?
注意:我正在Android 4.4上运行我的测试,目前您可以使用它,更改顺序:(这似乎是一个bug) (对user802421的回答) toolbar.xml
<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" />
我也有类似的问题。在经历了一次巨大的头痛之后,我发现我的ActionBarDrawerToggle正在修改图标,同时它也不应该修改图标(因为我没有将工具栏引用到切换组件)。因此,在我的NavigationDrawerFragment类(处理打开和关闭)中的
setUp(…)
方法中,我设置了mDrawerToggle.setHomeAsUpIndicator(R.drawable.app_图标)代码>
最后它成功了。对于导航图标,这是正确的顺序
// get the actionbar as Toolbar and set it up
Toolbar toolbar = (Toolbar) findViewById(R.id.signIn_toolbar);
setSupportActionBar(toolbar);
通知工具栏以提供向后导航。这会将图标设置为默认材质图标
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
稍后用自定义图标覆盖该图标,在我的例子中是Holo back图标
toolbar.setNavigationIcon(R.drawable.ic_chevron_left_white_36dp);
我试着像@Gabriele Mariotti那样设置工具栏,但我对标题有一些问题。于是我下了命令
toolbar.setTitle("Title")
setSupportActionBar(toolbar);
toolbar.setNavigationIcon(R.drawable.ic_good);
它是有效的。我刚刚找到了解决方案。其实很简单:
mDrawerToggle.setDrawerIndicatorEnabled(false);
希望它能对你有所帮助。我使用了下面的方法,这是上面所有方法中的一个难题。我还发现OnOptions ItemSelected从未激活
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();
}
});
}
您可以使用invalidate()
方法在任何位置更改工具栏状态。
例如:
试试这个:
<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>
使用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);
为我工作
<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"/>
如果您添加了
@Override
protected void onPostCreate(Bundle savedInstanceState) {
super.onPostCreate(savedInstanceState);
// Sync the toggle state after onRestoreInstanceState has occurred.
mDrawerToggle.syncState();
}
然后设置图标
getSupportActionBar().setHomeAsUpIndicator(icon);
如果不希望将工具栏设置为操作栏,可以使用以下方法:
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)
}
事实上,这是一个自定义图标的工作!如果想要默认图标,没有与sethomebuttonenabled(true)等效的图标,是吗?getSupportedActionBar().sethomebuttonenabled(true)@加布里埃马里奥蒂刚刚纠正!getSupportActionBar().setHomeButtonEnabled(true)@Jabbar_Jigariyo这似乎对我不起作用。设置home(主页)按钮是否也存在特定的订购错误?没关系,我找到了解决方法。您必须添加getSupportActionBar().setDisplayHomeAsUpEnabled(true)代码>将SupportActionBar设置到工具栏后。类似于设置导航图标。请说,如何获取mDrawerToggle
对象!android.support.v7.widget.Toolbar没有setDrawerIndicatorEnabledmethod@AdrianPreuss你应该自己创造它。示例:ActionBarDrawerToggle(活动、抽屉、工具栏、R.string.navigation\u drawer\u open、R.string.navigation\u drawer\u close)
这对我有效-终于!更改标准菜单图标的工作非常困难。我不明白为什么在其他一切都设置好之后,然后分配图标,这是可行的-有人知道吗?我已经做了很多次了,但不知怎么的,它现在对我不起作用了?值得注意的是,添加app:navigationIcon不推荐作为“所有Android设备都为这种类型的导航提供了后退按钮,因此您不应该在应用程序的UI中添加后退按钮”在尝试了许多不同的选项后,这个解决方案对我很有效。我相信这个选项toggle.isDrawerindIndicatorEnabled=false
对于确保可以设置新图标至关重要。
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);
<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"/>
@Override
protected void onPostCreate(Bundle savedInstanceState) {
super.onPostCreate(savedInstanceState);
// Sync the toggle state after onRestoreInstanceState has occurred.
mDrawerToggle.syncState();
}
getSupportActionBar().setHomeAsUpIndicator(icon);
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)
}