根据我的功能,我需要使用抽屉菜单和底部导航。我正在使用 https://github.com/roughike/BottomBar 进行底部导航。

如果我使用只有 3 个选项卡的底部导航,它可以正常工作,但如果我使用 4 或 5 个选项卡扩展它,它会在工具栏顶部出现空白。

这是我用于添加底部导航的代码 fragment 。

Activity _main.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/DrawerLayout" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@android:color/white" android:elevation="7dp" android:fitsSystemWindows="false" android:scrollbars="none">
    <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical">
        <include android:id="@+id/tool_bar" layout="@layout/row_main_toolbar_header"></include>
        <!-- The main content view -->
        <FrameLayout android:id="@+id/contentFrame" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_marginBottom="@dimen/dp_1" android:layout_marginTop="@dimen/dp_10" android:background="@android:color/white" android:orientation="vertical"></FrameLayout>
    </LinearLayout>
    <ListView android:id="@+id/lvDrawerMenu" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="start" android:background="@android:color/white" android:scrollbars="none"></ListView>
</android.support.v4.widget.DrawerLayout>

使用给定库进行底部导航不需要任何组件。

在 MainActivity.java 中添加底部导航。
BottomBar bottomBar = BottomBar.attach(this, savedInstanceState);
bottomBar.setItemsFromMenu(R.menu.home_tab_menu, new OnMenuTabSelectedListener() {
 @Override
 public void onMenuItemSelected(int itemId) {
  switch (itemId) {
   case R.id.recent_item:

    break;
   case R.id.favorite_item:

    break;
   case R.id.location_item:

    break;
   case R.id.planning_item:

    break;
   case R.id.saver_item:

    break;

  }
 }
});

row_main_toolbar_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@android:color/white"
    android:elevation="@dimen/dp_4"
    android:gravity="center"
    android:theme="@style/ThemeOverlay.AppCompat.Dark">

    <RelativeLayout
        android:id="@+id/RelativeLayout01"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="10dp">

        <TextView
            android:id="@+id/txtTBTitle"
            style="@style/CustomBlackHeaderText"
            android:layout_alignParentLeft="true"
            android:layout_alignParentStart="true"
            android:layout_alignParentTop="true"
            android:layout_centerVertical="true"
            android:layout_toLeftOf="@+id/imgTB4" />

        <ImageView
            android:id="@+id/imgTB4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:layout_toLeftOf="@+id/imgTB3"
            android:layout_toStartOf="@+id/imgTB3"
            android:padding="@dimen/dp_5" />

        <ImageView
            android:id="@+id/imgTB3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentTop="true"
            android:layout_centerVertical="true"
            android:layout_marginLeft="@dimen/dp_5"
            android:layout_toLeftOf="@+id/imgTB2"
            android:layout_toStartOf="@+id/imgTB2"
            android:padding="@dimen/dp_5" />


        <ImageView
            android:id="@+id/imgTB2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentTop="true"
            android:layout_centerVertical="true"
            android:layout_marginLeft="@dimen/dp_5"
            android:layout_toLeftOf="@+id/imgTB1"
            android:layout_toStartOf="@+id/imgTB1"
            android:padding="@dimen/dp_5" />

        <ImageView
            android:id="@+id/imgTB1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentEnd="true"
            android:layout_alignParentRight="true"
            android:layout_alignTop="@+id/txtTBTitle"
            android:layout_centerVertical="true"
            android:layout_marginLeft="@dimen/dp_5"
            android:padding="@dimen/dp_5" />

    </RelativeLayout>

</android.support.v7.widget.Toolbar>

android - 添加底部导航时在工具栏顶部获得不必要的空间-LMLPHP

android - 添加底部导航时在工具栏顶部获得不必要的空间-LMLPHP

最佳答案

创建默认底部导航栏时,activity_main 中将自动具有此属性:

android:paddingTop="?attr/actionBarSize"

所以只需删除它,您的应用程序顶部就没有空间

关于android - 添加底部导航时在工具栏顶部获得不必要的空间,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/39767852/

10-10 01:50