Android - 在CoordinatorLayout的Fragment中实现状态栏下方的工具栏

10

我正在开发一个带有CollapsingToolbarLayout的屏幕。

当我在Activity中使用这个布局时,一切都很好。

但是当我在Fragment中使用它时,工具栏会出现在状态栏下面。

在Activity中

在Fragment中

这是我的代码。请帮助我。谢谢。

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
    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"
    android:fitsSystemWindows="true"
    >
  <!--App Bar Layout-->
  <android.support.design.widget.AppBarLayout
      android:id="@+id/appbar_layout"
      android:layout_width="match_parent"
      android:layout_height="300dp"
      android:fitsSystemWindows="true"
      >
    <android.support.design.widget.CollapsingToolbarLayout
        android:id="@+id/collapsed_toolbar"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_scrollFlags="scroll|exitUntilCollapsed|snap"
    app:contentScrim="?attr/colorPrimary"
    >
  <android.support.v4.view.ViewPager
      android:id="@+id/view_pager"
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      android:fitsSystemWindows="true"
      app:layout_collapseMode="parallax"/>
  <ImageView
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      android:fitsSystemWindows="true"
      app:layout_collapseMode="parallax"
      android:src="@mipmap/ic_launcher"
      />
  <android.support.v7.widget.Toolbar
      android:id="@+id/toolbar"
      android:layout_width="match_parent"
      android:layout_height="?attr/actionBarSize"
      app:layout_collapseMode="pin"
      app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
      >
    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/lay_topbar"
        >
      <ImageView
          android:id="@+id/img_logo"
          android:layout_width="44dp"
          android:layout_height="44dp"
          android:background="#FF0000"
          android:layout_centerVertical="true"
          />
      <ImageButton
          android:id="@+id/imb_home"
          android:layout_width="44dp"
          android:layout_height="44dp"
          android:background="#00FF00"
          android:layout_alignParentRight="true"
          android:layout_centerVertical="true"
          />
      <ImageButton
          android:id="@+id/imb_cart"
          android:layout_width="44dp"
          android:layout_height="44dp"
          android:background="#0000FF"
          android:layout_toLeftOf="@id/imb_home"
          android:layout_centerVertical="true"
          />
    </RelativeLayout>
  </android.support.v7.widget.Toolbar>

</android.support.design.widget.CollapsingToolbarLayout>

1
将 android:fitsSystemWindows="true" 改为 android:fitsSystemWindows="false"。 - Aishwarya Tiwari
1
你好 @AishwaryaTiwari: 实际上,我想在向上滚动时显示状态栏下的内容。 - Duong Nguyen
请查看此链接:https://dev59.com/Yl0a5IYBdhLWcg3w-87a - rafsanahmad007
1
它不起作用 :( - Duong Nguyen
@DuongNguyen,你能否请发一下你的代码片段? - Ferdous Ahamed
不要在CoordinatorLayout和viewpager中使用android:fitsSystemWindows="true"。 - Ahamadullah Saikat
2个回答

14
我遇到了同样的问题。 放置:
android:fitsSystemWindows="true"

将此代码放在包含该片段的Activity布局的根目录中,而不是放在片段布局(在您的情况下是CoordinatorLayout)的根目录中。


Davide!感谢您让我找到正确的方向。 在我的情况下,我没有将它放在我的活动根目录中,而是将其放在我附加片段的容器元素中。 - DWndrer

0

尝试在CollapsingToolbarLayout中添加以下语句。

android:fitsSystemWindows="true"

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