如何隐藏底部导航栏?

3

我在 Android 中创建了底部导航栏,现在想要滚动时隐藏它,向下滑动时显示它。请问有人知道如何实现吗?我没有使用任何库来创建导航栏,而是使用了线性布局和相对布局。

这是 MainActivity.java 的 XML 文件:

<android.support.v4.widget.DrawerLayout
    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:id="@+id/MageNative_drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/white"
    android:fitsSystemWindows="true">
    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@color/white"
        android:orientation="vertical">
        <android.support.v7.widget.Toolbar
            android:id="@+id/MageNative_toolbar"
            android:layout_width="match_parent"
            android:layout_height="60dp"
            app:theme="@style/AppTheme">
            <ImageView
                android:id="@+id/toolimage"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:adjustViewBounds="true"
                android:contentDescription="@string/app_name"
                />
            <TextView
                android:id="@+id/tooltext"
                android:layout_width="wrap_content"
                android:layout_height="60dp"
                android:gravity="center_vertical"
                android:text="@string/app_name"
                android:textAllCaps="true"
                android:textColor="@color/black"
                android:textSize="15sp"
                android:visibility="gone"
                android:textStyle="bold"
                />
        </android.support.v7.widget.Toolbar>
        <FrameLayout
            android:id="@+id/MageNative_frame_container"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@color/white"
            android:layout_marginBottom="60dp"
            android:layout_below="@+id/MageNative_toolbar">
        </FrameLayout>
        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="60dp"
            android:id="@+id/bottom_toolbar"
            android:background="@color/white"
            android:layout_alignParentBottom="true">

            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:orientation="horizontal"
                android:layout_centerInParent="true"
                android:weightSum="1"
                android:baselineAligned="false"
                android:background="@color/white"
                android:layout_marginTop="10dp"
                >

                <LinearLayout
                    android:layout_width="0dp"
                    android:layout_weight="0.2"
                    android:id="@+id/home_icon_sect"
                    android:orientation="vertical"
                    android:layout_height="50dp">

                    <ImageView
                        android:layout_width="25dp"
                        android:layout_height="25dp"
                        android:layout_gravity="center_horizontal"
                        android:layout_marginTop="10dp"
                        android:tint="#343D4E"
                        android:src="@drawable/home"
                        android:id="@+id/home_icon"
                        />

                    <TextView
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:textColor="@color/black"
                        android:gravity="center"
                        android:textSize="11sp"
                        android:text="@string/home"/>

                </LinearLayout>

                <LinearLayout
                    android:layout_width="0dp"
                    android:layout_weight="0.2"
                    android:orientation="vertical"
                    android:id="@+id/categories"
                    android:layout_height="50dp">


                    <ImageView
                        android:id="@+id/wish_icon"
                        android:layout_width="25dp"
                        android:layout_height="25dp"
                        android:layout_gravity="center_horizontal"
                        android:layout_marginTop="10dp"
                        android:src="@drawable/home"
                        android:tint="#343D4E" />

                    <TextView
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:textColor="@color/black"
                        android:gravity="center"
                        android:textSize="11sp"
                        android:text="@string/categories"/>
                </LinearLayout>

                <LinearLayout
                    android:layout_width="0dp"
                    android:layout_weight="0.2"
                    android:orientation="vertical"
                    android:id="@+id/notification_icon_sect"
                    android:layout_height="50dp">

                    <ImageView
                        android:id="@+id/notification_icon"
                        android:layout_width="wrap_content"
                        android:layout_height="25dp"
                        android:layout_gravity="center_horizontal"
                        android:layout_marginTop="10dp"
                        android:src="@drawable/search"
                        android:tint="#343D4E" />

                    <TextView
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:gravity="center"
                        android:text="@string/search"
                        android:textColor="@color/black"
                        android:textSize="11sp" />

                </LinearLayout>

                <LinearLayout
                    android:layout_width="0dp"
                    android:layout_weight="0.2"
                    android:orientation="vertical"
                    android:id="@+id/user_icon_sect"
                    android:layout_height="50dp">

                    <ImageView
                        android:id="@+id/user_icon"
                        android:layout_width="25dp"
                        android:layout_height="25dp"
                        android:layout_gravity="center"
                        android:layout_marginTop="10dp"
                        android:src="@drawable/home"
                        android:tint="#343D4E" />

                    <TextView
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:textColor="@color/black"
                        android:gravity="center"
                        android:textSize="11sp"
                        android:text="@string/account"/>
                </LinearLayout>

                <LinearLayout
                    android:layout_width="0dp"
                    android:layout_weight="0.2"
                    android:id="@+id/drawer_menu_sect"
                    android:orientation="vertical"
                    android:layout_height="50dp">




                    <ImageView
                        android:id="@+id/drawer_menu"
                        android:layout_width="25dp"
                        android:layout_height="25dp"
                        android:layout_marginTop="10dp"
                        android:layout_centerHorizontal="true"
                        android:layout_gravity="center_horizontal"
                        android:src="@drawable/bag"
                        android:tint="#343D4E" />



                    <TextView
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:textColor="@color/black"
                        android:gravity="center"
                        android:layout_below="@+id/drawer_menu"
                        android:textSize="11sp"
                        android:text="@string/cart"/>

                </LinearLayout>
            </LinearLayout>
        </RelativeLayout>
    </RelativeLayout>
    <fragment
        android:id="@+id/MageNative_fragment_navigation_drawer"
        android:name="com.freshgrocy.app.maincontainer.FragmentDrawer"
        android:layout_width="290dp"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        android:fitsSystemWindows="true"
        app:layout="@layout/fragment_drawer"
        tools:layout="@layout/fragment_drawer" />
</android.support.v4.widget.DrawerLayout>

这个回答解决了你的问题吗?[如何在滚动时隐藏/显示bottomNavigationView] (https://dev59.com/mlcP5IYBdhLWcg3wLnNC) - Farzad Kamali
我在我的代码中没有使用BottomNavigationView库。请查看我提供的XML文件,您不会找到它。 - Areeb Khan
2个回答

1

我知道可能有点晚了,但我找到了答案。两个月前我一直在搜索但是没找到任何东西,但几分钟前我找到了解决方案并验证它能够在Android Kitkat版本以上很好地工作,并决定分享它。我从AppIntro库中提取它,下面是代码:

  public void setImmersiveMode(boolean isEnabled, boolean isSticky) {

        if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
            if(!isEnabled && isImmersiveModeEnabled) {
                getWindow().getDecorView().setSystemUiVisibility(
                        View.SYSTEM_UI_FLAG_LAYOUT_STABLE
                                | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
                                | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);

                isImmersiveModeEnabled = false;
            } else if(isEnabled) {

                int flags =  View.SYSTEM_UI_FLAG_LAYOUT_STABLE
                        | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
                        | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
                        | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
                        | View.SYSTEM_UI_FLAG_FULLSCREEN;

                if(isSticky) {
                    flags |= View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY;
                    isImmersiveModeSticky = true;
                } else {
                    flags |= View.SYSTEM_UI_FLAG_IMMERSIVE;
                    isImmersiveModeSticky = false;
                }

                getWindow().getDecorView().setSystemUiVisibility(flags);

                isImmersiveModeEnabled = true;
            }
        }
    }

在你的活动中:

public boolean isImmersiveModeEnabled = false;
public boolean isImmersiveModeSticky = false;

并在您的代码中使用:

setImmersiveMode(true,false);

或者

setImmersiveMode(true,false);

编程愉快 :)


0
只需在您的BottomNavigationView中添加app:layout_behavior="@string/hide_bottom_view_on_scroll_behavior"即可。
 <com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/bottom_navigation"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
       ....
        app:layout_behavior="@string/hide_bottom_view_on_scroll_behavior" />

但是如我之前所述,我并未使用它。请检查我分享的XML文件。 - Areeb Khan
但是为什么你要自己创建呢?BottomNavigationView 对你来说不起作用吗? - Vishal Nagvadiya

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接