web-dev-qa-db-ja.com

下部のナビゲーションバーに3つ以上のアイテムandroid

Androidを初めて使用し、下部のナビゲーションバーに3つ以上の要素を含むアプリを作成しようとしています。それらを表示することはできますが、最後にクラスター化され、3つしかありません。これが私のコードです:

<Android.support.design.widget.BottomNavigationView
    Android:id="@+id/bottomNavigation"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:elevation="15dp"
    Android:layout_gravity="bottom"
    Android:layout_alignParentBottom="true"
    app:menu="@menu/bottom_nav_items" />

ビューの画像は次のとおりです。 これはスナップショットです

私は立ち往生しています助けてください。

7
DonJon

よくわかりませんが、私の知る限り、配置を歪めることなく、下部のバーを使用して3つ以上のアイテムを添付することはできません。とにかくできることは、水平方向の線形レイアウトを作成し、その中でそれらのアイコンを画像ビューとして設定してから、それらの重みを1にすることです。

これがコードです、

<LinearLayout
    Android:layout_width="match_parent"
    Android:layout_height="50dp"
    Android:gravity="center"
    Android:layout_alignParentBottom="true"
    Android:background="#fff">

        <ImageView
            Android:layout_width="25dp"
            Android:layout_height="25dp"
            Android:src="(YOUR IMAGE SOURCE)"
            Android:layout_centerVertical="true"
            Android:layout_centerHorizontal="true"
            Android:layout_weight="1"/>

そして、このような他の画像ビュー。

3
Prateek Paliwal

クラスター化されたメニュー項目を取得しないために、以下の方法を使用できます。 BottomNavigationViewを渡してonCreateメソッドでこのメソッドを呼び出す必要があります。

// Method for disabling ShiftMode of BottomNavigationView
private 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);
            item.setShiftingMode(false);
            // set once again checked value, so view will be updated
            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);
    }
}
20
Maulik Dodia
     <Android.support.design.widget.BottomNavigationView
            Android:id="@+id/navigation"
            Android:layout_width="match_parent"
            Android:layout_height="wrap_content"
            Android:layout_gravity="bottom"
            Android:background="?android:attr/windowBackground"
            app:menu="@menu/navigation" />


navigation.xml(inside menu)
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:app="http://schemas.Android.com/apk/res-auto">

    <item
        Android:id="@+id/navigation_home"
        Android:icon="@drawable/ic_home_black_24dp"
        Android:title="@string/title_home"
        app:showAsAction="always|withText"
        Android:enabled="true"/>

    inside oncreate method
     BottomNavigationView navigation = (BottomNavigationView)findViewById(R.id.navigation);
      BottomNavigationViewHelper.disableShiftMode(navigation);//Dont forgot this line




    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);
            }
        }
    }
2
Kishore Reddy