如何在CollapsingToolbarLayout中固定RelativeLayout

时间:2017-01-05 05:37:42

标签: android android-layout

我正在使用CollapsingToolbarLayout进行我的活动。有没有办法固定包含工具栏的RelativeLayout而不是固定工具栏?我尝试执行以下操作,但是当布局崩溃时,RelativeLayout不会固定在顶部。

<?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">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appBarLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:elevation="0dp"
        android:theme="@style/AppTheme.AppBarOverlay"
        app:elevation="0dp"
        android:fitsSystemWindows="true">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsing_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:contentScrim="@color/pale_red"
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            android:fitsSystemWindows="true">

            <FrameLayout
                android:layout_width="match_parent"
                android:layout_height="230dp"
                android:fitsSystemWindows="true"
                app:layout_collapseMode="parallax">

                <android.support.v4.view.ViewPager
                    android:id="@+id/carViewPager"
                    android:layout_width="match_parent"
                    android:layout_height="230dp"/>

                <LinearLayout
                    android:id="@+id/image_count"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:orientation="horizontal"
                    android:gravity="center"
                    android:layout_gravity="bottom|center"
                    android:background="@android:color/transparent" />

            </FrameLayout>

            <RelativeLayout
                android:id="@+id/toolbarLayout"
                android:layout_width="match_parent"
                android:layout_height="@dimen/toolbar_height"
                app:layout_collapseMode="pin"
                app:popupTheme="@style/AppTheme.PopupOverlay">

                <android.support.v7.widget.Toolbar
                    android:id="@+id/toolbar"
                    android:layout_width="match_parent"
                    android:layout_height="@dimen/toolbar_height"
                    app:popupTheme="@style/AppTheme.PopupOverlay">

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

                <TextView
                    android:id="@+id/activityTitle"
                    android:layout_width="match_parent"
                    android:layout_height="48dp"
                    android:layout_gravity="center"
                    android:gravity="center"
                    android:textSize="16sp"
                    android:text="@string/shop_info"
                    android:textColor="@color/white" />

            </RelativeLayout>

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

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

    <include layout="@layout/content_shop" />

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

1 个答案:

答案 0 :(得分:1)

与其名称折叠一样,除了工具栏之外的其他内容在向上滚动时会折叠,唯一的方法是使用“ pin “在 ToolBar 上,只有工具栏与” pin “一起使用。 因此,请尝试将 RelativeLayout 置于 CollapsingToolBarLayout 之外,但在 AppBarLayout 内,可能就是您所需要的。

我通过这个问题解决了这个问题:

How to use a TabLayout with Toolbar inside CollapsingToolbarLayout?

只需将您的布局视为此问题中提到的 TabLayout

希望它有所帮助。