底部带有图标的 AppBar
Bottom AppBar with icons on both sides
默认情况下,fab 位于中心,所有图标都右对齐,但我需要在一侧和另一侧有 3 个图标,如下例所示。
屏幕截图显示了点击其中一个按钮,这样的涟漪出现在底部应用栏中(而不是底部导航中),点击时还会出现吐司,这只能与非假菜单项一起使用,而不是例如 imageButton。
重要的是每个图标都是一个真正的菜单项(而不是图像按钮),长按菜单项应该在图标上显示祝酒词(如您在屏幕截图中看到的),这一点非常重要。
非常感谢您的帮助!
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
app:showAsAction="always"
android:id="@+id/menu_home"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_home"
android:title="@string/title_home" />
<item
app:showAsAction="always"
android:id="@+id/menu_tasks"
android:icon="@drawable/ic_tasks"
android:title="@string/title_tasks" />
<item
app:showAsAction="always"
android:id="@+id/menu_habits"
android:icon="@drawable/ic_timer"
android:title="@string/title_pomo" />
<item
android:id="@+id/menu_timer"
app:showAsAction="always"
android:icon="@drawable/ic_habit"
android:title="@string/title_habits" />
</menu>
当前结果:
我做到了!我在 ActionMenuView 中放大了菜单的左侧。
布局中:
<com.google.android.material.bottomappbar.BottomAppBar
android:id="@+id/bottomAppBar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
android:contentInsetStart="0.0dip"
android:contentInsetLeft="0dp"
app:contentInsetLeft="0dp"
app:contentInsetStart="0dp"
app:menu="@menu/bottom_nav_menu_right">
<androidx.appcompat.widget.ActionMenuView
android:id="@+id/additional_menu"
android:layout_width="wrap_content"
android:layout_height="?actionBarSize" />
</com.google.android.material.bottomappbar.BottomAppBar>
bottom_nav_menu_left:
<?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_tasks"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_tasks"
android:title="tasks"
app:showAsAction="always" />
<item
android:id="@+id/menu_habit"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_habit"
android:title="habits"
app:showAsAction="always" />
<item
android:id="@+id/menu_add"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_add"
android:title="add"
app:showAsAction="always" />
</menu>
bottom_nav_menu_right:
<?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_nav"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_menu"
android:title="menu"
app:showAsAction="always" />
<item
android:id="@+id/menu_home"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_home"
android:title="home"
app:showAsAction="always" />
<item
android:id="@+id/menu_timer"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_timer"
android:title="timer"
app:showAsAction="always" />
</menu>
用左侧图标展开菜单:
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
...
val actionMenuView = findViewById<ActionMenuView>(...)
menuInflater.inflate(R.menu.bottom_nav_menu_left, actionMenuView.menu)
...
}
}
默认情况下,fab 位于中心,所有图标都右对齐,但我需要在一侧和另一侧有 3 个图标,如下例所示。
屏幕截图显示了点击其中一个按钮,这样的涟漪出现在底部应用栏中(而不是底部导航中),点击时还会出现吐司,这只能与非假菜单项一起使用,而不是例如 imageButton。
重要的是每个图标都是一个真正的菜单项(而不是图像按钮),长按菜单项应该在图标上显示祝酒词(如您在屏幕截图中看到的),这一点非常重要。 非常感谢您的帮助!
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
app:showAsAction="always"
android:id="@+id/menu_home"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_home"
android:title="@string/title_home" />
<item
app:showAsAction="always"
android:id="@+id/menu_tasks"
android:icon="@drawable/ic_tasks"
android:title="@string/title_tasks" />
<item
app:showAsAction="always"
android:id="@+id/menu_habits"
android:icon="@drawable/ic_timer"
android:title="@string/title_pomo" />
<item
android:id="@+id/menu_timer"
app:showAsAction="always"
android:icon="@drawable/ic_habit"
android:title="@string/title_habits" />
</menu>
当前结果:
我做到了!我在 ActionMenuView 中放大了菜单的左侧。
布局中:
<com.google.android.material.bottomappbar.BottomAppBar
android:id="@+id/bottomAppBar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
android:contentInsetStart="0.0dip"
android:contentInsetLeft="0dp"
app:contentInsetLeft="0dp"
app:contentInsetStart="0dp"
app:menu="@menu/bottom_nav_menu_right">
<androidx.appcompat.widget.ActionMenuView
android:id="@+id/additional_menu"
android:layout_width="wrap_content"
android:layout_height="?actionBarSize" />
</com.google.android.material.bottomappbar.BottomAppBar>
bottom_nav_menu_left:
<?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_tasks"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_tasks"
android:title="tasks"
app:showAsAction="always" />
<item
android:id="@+id/menu_habit"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_habit"
android:title="habits"
app:showAsAction="always" />
<item
android:id="@+id/menu_add"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_add"
android:title="add"
app:showAsAction="always" />
</menu>
bottom_nav_menu_right:
<?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_nav"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_menu"
android:title="menu"
app:showAsAction="always" />
<item
android:id="@+id/menu_home"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_home"
android:title="home"
app:showAsAction="always" />
<item
android:id="@+id/menu_timer"
android:layout_alignParentRight="true"
android:icon="@drawable/ic_timer"
android:title="timer"
app:showAsAction="always" />
</menu>
用左侧图标展开菜单:
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
...
val actionMenuView = findViewById<ActionMenuView>(...)
menuInflater.inflate(R.menu.bottom_nav_menu_left, actionMenuView.menu)
...
}
}