BottomNavigationView文本在更改时闪烁

时间:2018-02-02 13:32:20

标签: android xml selector drawable android-bottom-nav-view

这是闪烁的: http://gph.is/2GH9P0b

<android.support.design.widget.BottomNavigationView
       android:id="@+id/navigation"
       style="@style/BottomNavigation"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:layout_alignParentBottom="true"
       android:layout_marginEnd="0dp"
       android:layout_marginStart="0dp"
       app:layout_constraintBottom_toBottomOf="parent"
       app:layout_constraintLeft_toLeftOf="parent"
       app:layout_constraintRight_toRightOf="parent"
       app:menu="@menu/navigation" />

Styles.xml

<style name="BottomNavigation">
    <item name="android:background">@color/colorPrimary</item>
    <item name="itemIconTint">@drawable/nav_bottom_selector</item>
    <item name="itemTextColor">@drawable/nav_bottom_text_selector</item>
</style>

选择器nav_bottom_text_selectornav_bottom_selector具有相同的代码。

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:color="@android:color/white" android:state_checked="true"/>
    <item android:color="#6e6e6e" />

MainActivity.class这是标签更改监听器。但我不认为这个问题在这里,因为即使我评论这一部分它仍然是闪烁的。

navigation.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
        @Override
        public boolean onNavigationItemSelected (@NonNull MenuItem item) {

        switch (item.getItemId()) {
            case R.id.navigation_exercises:
                // even not replace tabs, just hide and show                          
                fragmentManager.beginTransaction().show(exerciseFragment).hide(workoutFragment).hide(profileFragment).commit();
                SharedPrefsHelper.getInstance().setLastTab(getApplicationContext(), ConsKeys.BOTTOM_TAB_EXERCISE);
                break;
            case R.id.navigation_workouts:
                fragmentManager.beginTransaction().hide(exerciseFragment).show(workoutFragment).hide(profileFragment).commit();
                SharedPrefsHelper.getInstance().setLastTab(getApplicationContext(), ConsKeys.BOTTOM_TAB_WORKOUTS);
                break;

            case R.id.navigation_profile:
                fragmentManager.beginTransaction().hide(exerciseFragment).hide(workoutFragment).show(profileFragment).commit();
                //Saving last tab     
                SharedPrefsHelper.getInstance().setLastTab(getApplicationContext(), ConsKeys.BOTTOM_TAB_PROFILE);


                break;
        }

        return true;
    }
    });

底部导航视图的导航menu.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">

    <item
        android:id="@+id/navigation_exercises"
        android:icon="@drawable/ic_home_black_24dp"
        android:title="@string/title_exercises" />

    <item
        android:id="@+id/navigation_workouts"
        android:icon="@drawable/ic_dashboard_black_24dp"
        android:title="@string/title_workouts" />

    <item
        android:id="@+id/navigation_profile"
        android:icon="@drawable/ic_notifications_black_24dp"
        android:title="@string/title_profile" />

</menu>

2 个答案:

答案 0 :(得分:0)

发生此问题是由于Android Q中引入的API更改影响了用于为 BottomNavigationView 菜单项设置动画的过渡。您有两种方法可以解决此问题:

第一个:将此依赖项包含在应用的等级中

implementation 'androidx.transition:transition:1.3.0-rc02'

这将替换库的转换机制,问题将消失。

第二:将您的目标SDK版本降低到API 28或更低。虽然,我只会在第一个解决方案不起作用的情况下才推荐此解决方案,因为您将失去在新版OS中引入的任何行为更改。

希望这会有所帮助!

答案 1 :(得分:-1)

这只是一种涟漪效应。这取决于您先点击按钮的哪个部分。如果单击底部附近,文本将首先变为白色。 如果你不喜欢它,你可以找到here如何禁用涟漪效应。