假设不同的菜单图标将显示在选项卡式活动的工具栏上的不同选项卡上。
一种解决方案是为每个片段/选项卡构建一个不同的菜单,并在相应的onCreateOptionsMenu()
函数处膨胀。然而,这种解决方案被证明是缓慢和滞后的。菜单图标消失得不够快。
第二种解决方案是在"活动"中放大所有菜单图标,然后在必要时隐藏。此选项速度更快。
我试过pageChangeListener
和tabSelectedListener
。但不知何故,菜单图标并没有在第一次点击时消失。在行中单击两个隐藏选项卡后,它们将消失。如果使用invalidateOptionsMenu()
,则菜单图标根本不会隐藏。
你知道为什么会发生这种事吗或者你有其他快速隐藏图标的方法吗
这是相关代码:
override fun onCreateOptionsMenu(menu: Menu?): Boolean {
Log.v("MainAct", "MainAct onCreateOptionsMenu")
menuInflater.inflate(R.menu.mainmenu, menu)
viewPager.addOnPageChangeListener(object : ViewPager.SimpleOnPageChangeListener() {
override fun onPageSelected(position: Int) {
when (position) {
0 -> {
menu!!.findItem(R.id.menuicon_contacts).isVisible = false
menu.findItem(R.id.menuicon_add).isVisible = false
invalidateOptionsMenu() // With this line menuicons does not disappear at all
}
1 -> {
menu!!.findItem(R.id.menuicon_contacts).isVisible = false
menu.findItem(R.id.menuicon_add).isVisible = false
invalidateOptionsMenu()
}
2 -> {
menu!!.findItem(R.id.menuicon_contacts).isVisible = true
menu.findItem(R.id.menuicon_add).isVisible = true
invalidateOptionsMenu()
}
}
}
})
return super.onCreateOptionsMenu(menu)
}
var menu1 : Boolean = true
on创建方法:
viewPager.addOnPageChangeListener(object : ViewPager.SimpleOnPageChangeListener() {
override fun onPageSelected(position: Int) {
when (position) {
0 -> {
menu1 = true
invalidateOptionsMenu()
}
1 -> {
menu1 = true
invalidateOptionsMenu()
}
2 -> {
menu1 = false
invalidateOptionsMenu()
}
}
}
})
覆盖方法:
override fun onCreateOptionsMenu(menu: Menu?): Boolean {
if(menu1){
menuInflater.inflate(R.menu.mainmenu1, menu)
}else{
menuInflater.inflate(R.menu.mainmenu2, menu)
}
return super.onCreateOptionsMenu(menu)
}
override fun onOptionsItemSelected(item: MenuItem): Boolean {
when (item.itemId) {
R.id.menuicon_contacts -> {
// your code
return true
}
R.id.menuicon_add -> {
// your code
return true
}
}
return super.onOptionsItemSelected(item)
}