BottomNavigationView уменьшить размер после нажатия элемента BottomNavView? - PullRequest
0 голосов
/ 27 марта 2019

Когда я нажимаю на нижний элемент навигации, размер BottomNavigationView автоматически уменьшается.Это происходит только при передаче управления с домашнего предмета на любой другой предмет.Когда я нажимаю на любой другой элемент в третий раз, он автоматически возвращается к исходному размеру.

.,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,

 BottomNavigationView bottomNavigationView = findViewById(R.id.bottom_nav_view);
        bottomNavigationView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem menuItem) {
                Fragment selectedFragment = null;


                switch (menuItem.getItemId()){
                    case R.id.home_bottom_nav:
                        selectedFragment = new HomeFragment();
                        break;
                    case R.id.game_bottom_nav:
                        selectedFragment = new GameFragment();
//                        selectedFragment = GameFragment.newInstance("Para1","Para2");
                        break;
                    case R.id.even_bottom_nav:
                        selectedFragment = new EventFragment();
                        break;
                    case R.id.profile_bottom_nav:
                        selectedFragment = new ProfileFragment();
                        break;
                }

                assert selectedFragment != null;
                getSupportFragmentManager().beginTransaction().replace(R.id.fragmentLayout,selectedFragment)
                        .commit();

                return true;
            }
        });

        getSupportFragmentManager().beginTransaction().replace(R.id.fragmentLayout,new HomeFragment()).commit();

XML-код

<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".HomeActivity">

    <FrameLayout
        android:id="@+id/fragmentLayout"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        app:layout_constraintBottom_toTopOf="@+id/bottom_nav_view"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <android.support.design.widget.BottomNavigationView
        android:id="@+id/bottom_nav_view"
        android:layout_width="match_parent"
        android:layout_height="56dp"
        android:background="?android:attr/windowBackground"
        app:itemTextAppearanceActive="@style/Widget.BottomNavigationView"
        app:labelVisibilityMode="labeled"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:menu="@menu/bottom_nav_items" />

</android.support.constraint.ConstraintLayout>

enter image description here

enter image description here

enter image description here

Ответы [ 3 ]

0 голосов
/ 27 марта 2019

Измените свою нижнюю навигацию xml и ширину фрейма 0dp.Также укажите ограничение верхней части нижней навигационной точки и высоту wrap_content.

<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".HomeActivity">

    <FrameLayout
        android:id="@+id/fragmentLayout"
        android:layout_width="0dp"
        android:layout_height="0dp"
        app:layout_constraintBottom_toTopOf="@+id/bottom_nav_view"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <android.support.design.widget.BottomNavigationView
        android:id="@+id/bottom_nav_view"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:background="?android:attr/windowBackground"
        app:itemTextAppearanceActive="@style/Widget.BottomNavigationView"
        app:labelVisibilityMode="labeled"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/fragmentLayout"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:menu="@menu/bottom_nav_items" />

</android.support.constraint.ConstraintLayout>
0 голосов
/ 27 марта 2019

Попробуйте это

<android.support.design.widget.BottomNavigationView
        android:id="@+id/bottom_nav_view"
        android:layout_width="0dp"
        android:layout_height="56dp"
        android:background="?android:attr/windowBackground"
        app:itemTextAppearanceActive="@style/Widget.BottomNavigationView"
        app:labelVisibilityMode="labeled"
        app:menu="@menu/bottom_nav_items"

        app:itemHorizontalTranslationEnabled="false"
        app:itemTextAppearanceInactive="@style/Widget.BottomNavigationView"

        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
 />

0 голосов
/ 27 марта 2019

Можете ли вы перепроверить свой BottomNavigaionView следующим образом: используйте wrap_content и alignParentBottom. Попробуйте изменить высоту FrameLayout на wrap_content и удалите эту строку app: layout_constraintEnd_toEndOf = "parent"

<com.google.android.material.bottomnavigation.BottomNavigationView
    android:id="@+id/bottom_navigation"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:background="#ffffff"
    app:labelVisibilityMode="labeled"
    app:menu="@menu/menu_buttom_navigation" />
...