BottomNavigationView は、非アクティブなメニューのタイトルを表示しません。
bottomNavigationBar のすべてのメニュー要素のタイトルを表示するには? 問題は、私の場合、クリックされた要素のタイトルのみが表示されることです。
BottomNavigationView は、非アクティブなメニューのタイトルを表示しません。
bottomNavigationBar のすべてのメニュー要素のタイトルを表示するには? 問題は、私の場合、クリックされた要素のタイトルのみが表示されることです。
has 条件の実装BottomNavigationView
: アイテムが 3 つ以上ある場合は、シフト モードを使用します。
現時点では、既存の API を使用して変更することはできません。シフト モードを無効にする唯一の方法は、リフレクションを使用することです。
ヘルパー クラスが必要です。
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 {
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);
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);
}
}
}
次にdisableShiftMode
メソッドを に適用しますBottomNavigationView
が、コードからメニュービューを膨張させる場合は、膨張後に実行する必要があることに注意してください。
使用例:
BottomNavigationView bottomNavigationView = (BottomNavigationView) findViewById(R.id.bottom_navigation_bar);
BottomNavigationViewHelper.disableShiftMode(bottomNavigationView);
PS。
のメニュー項目を変更するたびに、このメソッドを実行する必要があることに注意してくださいBottomNavigationView
。
アップデート
また、proguard 構成ファイル (proguard-rules.pro など) を更新する必要があります。上記のコードはリフレクションを使用しており、proguard がmShiftingMode
フィールドを難読化すると機能しません。
-keepclassmembers class android.support.design.internal.BottomNavigationMenuView {
boolean mShiftingMode;
}
この問題を指摘し、スニペットを提供してくれた Muhammad Alfaifi に感謝します。
更新 2
Jolanda Verhoef が指摘したように、新しいサポート ライブラリ ( 28.0.0-alpha1
) と新しいマテリアル コンポーネント ライブラリ( 1.0.0-beta01
) は、3 つのメニュー項目でシフト モードを操作するために使用できるパブリック プロパティを提供します。
<com.google.android.material.bottomnavigation.BottomNavigationView
...
app:labelVisibilityMode="labeled"
...
/>
Material Components ライブラリでは、メニュー項目が 5 つある場合にも適用されます。
更新 3
@ThomasSunderland も指摘したように、 postfixapp:itemHorizontalTranslation="false"
なしでこのプロパティを false に設定して、Enabled
アニメーションのシフトを無効にすることができます。
ここで、BottomNavigation のスタイリングに関する完全なガイドを確認できます。
Since support library 28.0.0-alpha1:
<android.support.design.widget.BottomNavigationView
app:labelVisibilityMode="labeled" />
テキスト アニメーションを無効にするには、dimens.xml ファイルでこれを使用することもできます。
<dimen name="design_bottom_navigation_active_text_size">12sp</dimen>
これをマニフェストに追加する必要がある場合もあります。
tools:override="true"
テキスト アニメーションを無効にしてフォント サイズを小さくするには、dimens.xml ファイルでこれを使用します。
<dimen name="design_bottom_navigation_text_size">10sp</dimen>
<dimen name="design_bottom_navigation_active_text_size">10sp</dimen>
私のために働く
bottomNavigationView.setLabelVisibilityMode(LabelVisibilityMode.LABEL_VISIBILITY_LABELED);
また
<android.support.design.widget.BottomNavigationView
app:labelVisibilityMode="labeled" />
このメソッドの上に追加したいだけです disableShiftMode コードの下にも追加します。@SuppressLint("RestrictedApi")