具有3个以上项目的BottomNavigationView:选项卡标题正在隐藏

Yun*_*dar 68 android bottombar

我在使用Android支持设计库25时使用BottomNavigationView.但是当我切换选项卡时,其他选项卡的标题正在隐藏.但实际的底部导航视图没有隐藏问题.但我的藏匿.

MyBottomNavigation

但我希望它看起来像那样.有没有想过这样做?我错过了什么?

ActualBottomNavigation

这是我的代码:

activity_main.xml中

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.yunus.ototakip.MainActivity">

<FrameLayout
    android:id="@+id/main_container"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_above="@+id/bottom_navigation"
    android:layout_alignParentTop="true">
</FrameLayout>

<android.support.design.widget.BottomNavigationView
    android:id="@+id/bottom_navigation"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    app:itemBackground="@color/colorPrimary"
    app:itemIconTint="@color/beyaz"
    app:itemTextColor="@color/beyaz"
    app:menu="@menu/bottombar_menu" />
Run Code Online (Sandbox Code Playgroud)

bottom_bar_menu.xml

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
 <item
android:id="@+id/bb_menu_arac"
android:enabled="true"
android:icon="@drawable/icon_car"
android:title="@string/araclarim"
app:showAsAction="ifRoom" />
 <item
android:id="@+id/bb_menu_yakin"
android:enabled="true"
android:icon="@drawable/icon_yer"
android:title="@string/yakinimdakiler"
app:showAsAction="ifRoom" />
  <item
android:id="@+id/bb_menu_yaklasan"
android:enabled="true"
android:icon="@drawable/icon_takvim"
android:title="@string/yaklasanlar"
app:showAsAction="ifRoom" />

<item
    android:id="@+id/bb_menu_ipucu"
    android:enabled="true"
    android:icon="@drawable/icon_ipucu"
    android:title="@string/ipuclari"
    app:showAsAction="ifRoom" />
 </menu>
Run Code Online (Sandbox Code Playgroud)

Dan*_*ado 93

使用反射的解决方案不再起作用,因为删除了字段mShiftingMode.

现在有一种简单的方法:使用Support Library 28并添加app:labelVisibilityMode="labeled"BottomNavigationViewXML声明中.

希望能帮助到你.


raf*_*007 83

UPDATE

不再需要removeShiftMode(),因为在支持库28.0.0-alpha1中我们现在可以添加标签.

在XML中:

<android.support.design.widget.BottomNavigationView
    app:labelVisibilityMode="labeled" />
Run Code Online (Sandbox Code Playgroud)

以编程方式更改:

mBottomNavigationView.setLabelVisibilityMode(LabelVisibilityMode.LABEL_VISIBILITY_LABELED); 
Run Code Online (Sandbox Code Playgroud)

为此,请将设计支持库更新为28.0.0-alpha1

这是一个很好的阅读

对于老年人支持图书馆:

在你的.bottom_bar_menu.xml更改showAsAction属性

<item android:id="@id/menu_item"
android:title="text"
android:icon="@drawable/drawable_resource_name"
android:showAsAction="always|withText" />
Run Code Online (Sandbox Code Playgroud)

在build.gradle中:

compile 'com.android.support:design:25.3.1'
Run Code Online (Sandbox Code Playgroud)

BOTTOM NAVIGATIONVIEW超过3个项目:使用removeShiftMode()方法

BottomNavigationViewHelper.java使用中:

import android.annotation.SuppressLint;
import android.support.design.internal.BottomNavigationItemView;
import android.support.design.internal.BottomNavigationMenuView;
import android.support.design.widget.BottomNavigationView;
import java.lang.reflect.Field;

    public class BottomNavigationViewHelper {
        @SuppressLint("RestrictedApi")
        public static void removeShiftMode(BottomNavigationView view) {
            BottomNavigationMenuView menuView = (BottomNavigationMenuView) view.getChildAt(0);
            try {
                Field shiftingMode = menuView.getClass().getDeclaredField("mShiftingMode");
                shiftingMode.setAccessible(true);
                shiftingMode.setBoolean(menuView, false);
                shiftingMode.setAccessible(false);
                for (int i = 0; i < menuView.getChildCount(); i++) {
                    BottomNavigationItemView item = (BottomNavigationItemView) menuView.getChildAt(i);
                    //noinspection RestrictedApi
                    item.setShiftingMode(false);
                    // set once again checked value, so view will be updated
                    //noinspection RestrictedApi
                    item.setChecked(item.getItemData().isChecked());
                }
            } catch (NoSuchFieldException e) {
                Log.e("BottomNav", "Unable to get shift mode field", e);
            } catch (IllegalAccessException e) {
                Log.e("BottomNav", "Unable to change value of shift mode", e);
            }
        }
    }
Run Code Online (Sandbox Code Playgroud)

用它来调用:

BottomNavigationView bottomNavigationView = (BottomNavigationView)findViewById(R.id.bottom_navigation);
BottomNavigationViewHelper.removeShiftMode(bottomNavigationView);
Run Code Online (Sandbox Code Playgroud)

它将禁用标题文本的移动动画并启用文本显示.

  • 不,它仍然隐藏着.我试过"总是"和"总是| withText" (2认同)
  • 请参阅您正在关注的教程中的这一行`重要的是要注意我们可以显示的最大项目数是 5。这可能随时更改,因此使用 BottomNavigationView 提供的 getMaxItem() 方法检查这一点很重要类而不是自己硬编码值。` (2认同)
  • 反射解决方案在`com.android.support:design:25.4.0`上工作得很好,但在`com.android.support:design:26.1.0`上失败,所以我回滚了目标SDK和依赖项的版本a小. (2认同)

Scu*_*dam 10

扫描完BottomNavigationView的源代码后,我找到了

mShiftingMode = mMenu.size() > 3;
Run Code Online (Sandbox Code Playgroud)

BottomNavigationMenuView.java第265行中,它意味着当菜单大小超过3时,标签标题将被隐藏.因此,如果您想要显示标签标题,您只需要从构建中获取代码并将其更改为以下内容.

mShiftingMode = mMenu.size() > 5;
Run Code Online (Sandbox Code Playgroud)

PS:BottonNavigationView最大标签计数必须介于3和5之间.您可以在BottomNavigationViewNew上获取代码 在此输入图像描述


小智 8

创建类BottomNavigationViewHelper

import android.annotation.SuppressLint;
import android.support.design.internal.BottomNavigationItemView;
import android.support.design.internal.BottomNavigationMenuView;
import android.support.design.widget.BottomNavigationView;
import android.util.Log;
import java.lang.reflect.Field;
public class BottomNavigationViewHelper {
    @SuppressLint("RestrictedApi")
    public static void disableShiftMode(BottomNavigationView view) {
        BottomNavigationMenuView menuView = (BottomNavigationMenuView) view.getChildAt(0);
        try {
            Field shiftingMode = menuView.getClass().getDeclaredField("mShiftingMode");
            shiftingMode.setAccessible(true);
            shiftingMode.setBoolean(menuView, false);
            shiftingMode.setAccessible(false);
if(menuView.getChildCount()<6)
           {
            for (int i = 0; i < menuView.getChildCount(); i++) {
                BottomNavigationItemView item = (BottomNavigationItemView) menuView.getChildAt(i);
                //noinspection RestrictedApi
                item.setShiftingMode(false);
                // set once again checked value, so view will be updated
                //noinspection RestrictedApi
                item.setChecked(item.getItemData().isChecked());
            }
         }
        } catch (NoSuchFieldException e) {
            Log.e("BNVHelper", "Unable to get shift mode field", e);
        } catch (IllegalAccessException e) {
            Log.e("BNVHelper", "Unable to change value of shift mode", e);
        }
    }
}   
Run Code Online (Sandbox Code Playgroud)

呼叫

    BottomNavigationView bottomNavigationView = (BottomNavigationView)findViewById(R.id.bottom_navigation);
    BottomNavigationViewHelper.disableShiftMode(bottomNavigationView); 
Run Code Online (Sandbox Code Playgroud)


can*_*ler 5

应用程序:labelVisibilityMode =“标记”

将以上代码添加到您的 XML 文件下。

例子:

xmlns:app="http://schemas.android.com/apk/res-auto"


<com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/bottom_nav_view"
        ....
        ....
        app:labelVisibilityMode="labeled"/>
Run Code Online (Sandbox Code Playgroud)