在Viewpager里面的CollapsingToolbarLayout:工具栏表现奇怪

时间:2017-04-14 15:20:25

标签: android android-fragments android-viewpager android-collapsingtoolbarlayout

我有一个带有片段的viewpager,每个片段都应包含一个Collapsing工具栏+图像标题。

布局很好,但我有工具栏的这种奇怪的行为,有时会忽略上边距并在系统栏下结束。发生这种情况:

  • 在第一个标签
  • 上 滚动到标签3或更多,
  • 到任何“第一个 previus标签“
  • 它一次只发生在一个标签上(据我所见)

同样在第一个标签页上,菜单不会膨胀,尽管运行OnCreateOptionsMenu并且不会抛出任何错误。

我多次查看代码并做了很多调整但是,为了我,我找不到我做错了什么!

添加屏幕截图和一些代码。如果您想要运行它并且看到这一点,那么这是a Github repository。谢谢你的帮助!

enter image description here enter image description here

当向左滚动时会发生这种情况: enter image description here

activity_main.xml中

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.view.ViewPager
    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/container"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

fragment_main.xml

<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:id="@+id/main_content"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:context="com.manzo.tabbednavigation.MainActivity">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/app_bar_layout"
        android:layout_width="match_parent"
        android:layout_height="@dimen/appbar_height"
        android:fitsSystemWindows="true"
        android:theme="@style/AppTheme.AppBarOverlay">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsing_toolbar_layout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:title="Title"
            app:contentScrim="?attr/colorPrimary"
            android:fitsSystemWindows="true"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">


            <ImageView
                android:id="@+id/iv_scroll_header"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:scaleType="centerCrop"
                app:layout_collapseMode="parallax"
                android:fitsSystemWindows="true"
                android:src="@drawable/bg"/>

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                android:background="@color/colorAccentWarning"
                app:layout_collapseMode="pin"
                app:popupTheme="@style/AppTheme.PopupOverlay" />

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

    <android.support.v4.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <TextView
            android:id="@+id/section_label"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

    </android.support.v4.widget.NestedScrollView>
</android.support.design.widget.CoordinatorLayout>

1 个答案:

答案 0 :(得分:0)

我没有找到解决方案,所以我最终使用了一种解决方法。

我从工具栏中删除了fitsSystemWindows =“true”并添加了一个24dp的marginTop,即material guidelines的系统栏高度,我还包含了之前sdks的25dp高度。

<android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:layout_marginTop="@dimen/status_bar_height"
            app:layout_collapseMode="pin"
            app:popupTheme="@style/AppTheme.PopupOverlay" />

我对任何关于“真实”解决方案的建议持开放态度