android - BottomNavigationView 文本调整大小动画问题基于所使用的主题

标签 android material-design bottomnavigationview

我正在使用 BottomNavigationView,但观察到一个奇怪的问题。

当与主题“Theme.AppCompat.Light.DarkActionBar”一起使用时,文本和图标调整大小动画在单击每个项目时效果良好。

但是当与主题“Theme.MaterialComponents.Light.DarkActionBar”一起使用时, 它不起作用,没有发生调整大小动画。

<com.google.android.material.bottomnavigation.BottomNavigationView
    android:id="@+id/bottomNav"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom"
    android:background="#212121"
    app:itemIconTint="@color/nav_item_color_state"
    app:itemTextColor="@color/nav_item_color_state"
    app:menu="@menu/bottom_menu_main"/>

nav_item_color_state.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:id="@+id/action_nav_feed"
        android:icon="@android:drawable/ic_input_add"
        android:checked="true"
        android:title="List"/>
    <item
        android:id="@+id/action_nav_info"
        android:icon="@android:drawable/ic_notification_overlay"
        android:title="Info"/>
    <item
        android:id="@+id/action_nav_profile"
        android:icon="@android:drawable/ic_delete"
        android:title="Profile"/>
</menu>

style.xml

<style name="AppTheme" parent="Theme.MaterialComponents.Light.DarkActionBar">
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
</style>
<!-- Theme.AppCompat.Light.DarkActionBar -->

最佳答案

尝试使用属性 app:itemTextAppearanceActiveapp:itemTextAppearanceInactive

<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottomNav"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
android:background="#212121"
app:itemIconTint="@color/nav_item_color_state"
app:itemTextAppearanceActive="@style/BottomNavigationView.Active"
app:itemTextAppearanceInactive="@style/BottomNavigationView"
app:itemTextColor="@color/nav_item_color_state"
app:menu="@menu/bottom_menu_main"/>

styles.xml

<style name="BottomNavigationView" 
   parent="@style/TextAppearance.AppCompat.Caption">
    <item name="android:textSize">10sp</item>
</style>

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

无需为此 View 设置主题,这些样式即可完成任务。

关于android - BottomNavigationView 文本调整大小动画问题基于所使用的主题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54742777/

相关文章:

java - 底部导航 FindViewById 获取 null (kotlin)

带有背景颜色的 Android 按钮图标

java - BitmapFactory for java 给出 OutOfMemory 异常,想要 > 12mb...不知道为什么它这么大

Android MediaPlayer java.io.IOException : Prepare failed.:状态=0x1

android - 当用户向下滚动时如何逐渐将透明操作栏变成纯色

android - KOTLIN-BottomNavigationBar中的第一项不可见,标题问题

java - .setBackgroundResource(0) 使我的应用程序崩溃

css - 为什么 Material 组件卡标题与底部对齐?

html - 每张 MDlite 卡的新背景图片

java - 如何在 BottomNavigationView 中的项目上设置长按监听器?