如何更改选定的BottomNavigationView图标大小

3

我正在使用原生的BottomNavigationView,想把选中的图标大小调整为大于未选中图标的大小(比如选中的图标为40dp,其他图标大小为20dp)。

    <com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/bottom_navigation"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:layout_alignParentBottom="true"
        android:layout_centerVertical="true"
        android:scaleType="center"
        style="@style/Widget.Design.BottomNavigationView"
        app:labelVisibilityMode="unlabeled"
        app:menu="@menu/navigation_menu" />

<item
    android:id="@+id/homePageFragment"
    android:icon="@drawable/selector_nav_home"
    android:orderInCategory="1"
    android:title="" />

<item
    android:id="@+id/discoverPageFragment"
    android:icon="@drawable/selector_nav_discover"
    android:orderInCategory="2"
    android:title="" />

<item
    android:id="@+id/qrPageFragment"
    android:icon="@drawable/selector_nav_qr"
    android:orderInCategory="3"
    android:title="" />

<item
    android:id="@+id/myAccountFragment"
    android:icon="@drawable/selector_nav_profile"
    android:orderInCategory="4"
    android:title="" />

<item android:drawable="@drawable/ic_bottom_navigation_profile" android:state_checked="true"/>

<item android:drawable="@drawable/ic_navigation_profile" android:state_checked="false"/>


也许这能帮到你:https://dev59.com/i1gR5IYBdhLWcg3wRbk1 - Lukas
我检查了那个问题,但它改变了所有图标 @DuyiLian - enderkoca
您可以使用较大尺寸的ic_bottom_navigation_profile,然后再使用ic_navigation_profile。 - Nidhi Savaliya
@NidhiSavaliya,这并没有解决我的问题 :( - enderkoca
2个回答

3

您可以像这样更改所选项目的文本大小:

styles.xml:

<style name="bottomNavigationView.Active" parent="@style/TextAppearance.AppCompat.Caption">
        <item name="android:textSize">16sp</item>
</style>

bottom_navigation_view.xml:

<?xml version="1.0" encoding="utf-8"?>
<com.google.android.material.bottomnavigation.BottomNavigationView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/bottomNavView"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="?android:attr/windowBackground"
    app:menu="@menu/bottom_nav_menu"
    app:labelVisibilityMode="labeled"
    app:itemIconSize="24dp"
    android:scaleType="center"
    app:itemTextAppearanceActive="@style/bottomNavigationView.Active" />

由于文本大小增加,所选项目的图标会上升,整个元素看起来像是增大了:

就像这样


0

尝试这个来改变所选项目的图标大小

override fun onNavigationItemSelected(item: MenuItem): Boolean {
    changeItemIconSize(item.itemId)
    return true
}     

private fun changeItemIconSize(selectedItemId: Int) {
    val displayMetrics = resources.displayMetrics
    val menuView = bottomMenu.getChildAt(0) as BottomNavigationMenuView
    bottomMenu.itemIconSize = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 24f, displayMetrics).toInt()
    val iconViewSelected =
        menuView.findViewById<View>(selectedItemId).findViewById<View>(com.google.android.material.R.id.icon)
    val layoutParams = iconViewSelected.layoutParams
    layoutParams.height =
        TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 32f, displayMetrics).toInt()
    layoutParams.width =
        TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 32f, displayMetrics).toInt()
    iconViewSelected.layoutParams = layoutParams
}

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