使用viewpager时,CollapsingToolbarLayout不会折叠

时间:2016-08-23 03:32:11

标签: android android-viewpager android-coordinatorlayout android-collapsingtoolbarlayout

我在这里搜索了与我的问题相关的所有问题但到目前为止没有任何帮助。我想要实现的是当ViewPager中的片段向下滚动并且TabLayout只是pin时,中间工具栏会崩溃。这是我的主布局文件的结构。当我向下滚动时没有任何反应。

请帮帮我。任何帮助将不胜感激

<android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:theme="@style/AppTheme.AppBarOverlay">

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

    <android.support.design.widget.CollapsingToolbarLayout
        android:layout_height="72dp"
        android:id="@+id/collapsing_toolbar"
        android:layout_width="match_parent"
        android:fitsSystemWindows="true"
        android:background="@color/colorPrimary"
        app:layout_scrollFlags="scroll|exitUntilCollapsed"
        app:popupTheme="@style/AppTheme.PopupOverlay">

        <android.support.v7.widget.Toolbar
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:fitsSystemWindows="true"
            app:layout_collapseMode="parallax">

            <RelativeLayout android:id="@+id/relativeLayout"
                android:layout_width="match_parent"
                android:fitsSystemWindows="true"
                android:layout_gravity="top"
                android:paddingRight="20dp"
                android:paddingLeft="20dp"
                android:layout_height="wrap_content">

                <TextView android:id="@+id/tv_song_name"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textColor="#FFFFFF"
                    android:layout_alignParentLeft="true"
                    android:textSize="20sp"
                    android:ellipsize="marquee"
                    android:singleLine="true"
                    android:text="Bloody Stream"/>
                <TextView android:id="@+id/tv_artist"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_alignParentLeft="true"
                    android:layout_below="@+id/tv_song_name"
                    android:textSize="15sp"
                    android:fontFamily="Sans-serif-light"
                    android:textColor="#9E9E9E"
                    android:text="by Coda"/>
            </RelativeLayout>

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

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

    <android.support.design.widget.TabLayout
        android:id="@+id/tabs"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/colorPrimary"
        android:layout_below="@+id/tool_bar"
        android:layout_gravity="center_horizontal"
        android:layout_alignParentStart="true"
        android:fitsSystemWindows="true"
        app:tabGravity="fill"
        app:tabMode="fixed"/>
</android.support.design.widget.AppBarLayout>


<android.support.v4.view.ViewPager
    android:id="@+id/viewpager"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>


<android.support.design.widget.FloatingActionButton
    android:id="@+id/fab"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom|end"
    android:layout_margin="@dimen/fab_margin"
    android:src="@drawable/ic_file_download_white_24dp" />

2 个答案:

答案 0 :(得分:2)

Fragment中的滚动容器必须支持嵌套滚动。这意味着您应该使用NestedScrollViewRecyclerView

答案 1 :(得分:0)

似乎我必须在CollapsingToolbarLayout中包含具有导航后退按钮的工具栏。它按照我现在的意图工作。谢谢你的所有答案。

<?xml version="1.0" encoding="utf-8"?>

<android.support.design.widget.AppBarLayout
    android:id="@+id/smooth_appbar_layout"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:theme="@style/AppTheme.AppBarOverlay">


    <android.support.design.widget.CollapsingToolbarLayout
        android:layout_height="wrap_content"
        android:id="@+id/collapsing_toolbar"
        android:layout_width="match_parent"
        app:titleEnabled="false"
        android:fitsSystemWindows="true"
        android:background="@color/colorPrimary"
        app:layout_scrollFlags="scroll|enterAlwaysCollapsed"
        app:popupTheme="@style/AppTheme.PopupOverlay">


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

        <android.support.v7.widget.Toolbar
            android:layout_width="match_parent"
            android:layout_height="72dp"
            android:layout_marginTop="?android:attr/actionBarSize"
            app:layout_collapseMode="parallax">