CollapsingToolbarLayout:意外的视图堆栈行为

CollapsingToolbarLayout: unexpected view stack behavior

CollapsingToolbarLayout(自定义 FrameLayout)的子项似乎不符合 FrameLayout 的预期堆栈行为。我希望视图按照它们在 XML 布局中提供的顺序在彼此之上绘制。

在下面的示例中,当折叠 CollapsingToolbarLayout 时,“layout_button_bar” LinearLayout 在“button_follow”和“button_like”下方滚动纽扣。如果 LinearLayout 是在上述按钮之后定义的,我希望 LinearLayout 滚动到两个按钮上方,遮住它们,而不是在它们下方。有人熟悉解决方法吗?

<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/coordinator_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/app_bar_layout"
        android:layout_width="match_parent"
        android:layout_height="@dimen/collapsible_app_bar_height"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

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

            <ImageView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_gravity="center_horizontal"
                android:src="@drawable/some_image"
                app:layout_collapseMode="parallax"/>

            <ImageView
                android:id="@+id/image_header_gradient"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:src="@drawable/scrim_top_bottom_banner"
                app:layout_collapseMode="parallax"
                tools:ignore="ContentDescription"/>

            <android.support.v7.widget.Toolbar
                android:id="@+id/collapsible_toolbar"
                android:layout_width="match_parent"
                android:layout_height="104dp"
                android:minHeight="?attr/actionBarSize"
                android:gravity="top"
                android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
                app:layout_collapseMode="pin"/>

            <Button
                android:id="@+id/button_follow"
                android:layout_width="@dimen/text_button_width"
                android:layout_height="wrap_content"
                android:layout_gravity="bottom|start"
                android:layout_marginStart="@dimen/bottom_landing_button_margin"
                android:layout_marginBottom="@dimen/slide_handle_height"
                android:gravity="center_vertical|start"
                android:drawablePadding="@dimen/spacing_xsmall"
                android:drawableStart="@drawable/selector_follow"
                android:visibility="gone"
                android:textColor="@color/vertigo_alabaster_white"
                app:layout_collapseMode="parallax"/>

            <Button
                android:id="@+id/button_like"
                android:layout_width="@dimen/text_button_width"
                android:layout_height="wrap_content"
                android:layout_gravity="bottom|start"
                android:layout_marginStart="@dimen/bottom_landing_button_margin"
                android:layout_marginBottom="@dimen/slide_handle_height"
                android:gravity="center_vertical|start"
                android:drawablePadding="@dimen/spacing_xsmall"
                android:drawableStart="@drawable/selector_like"
                android:visibility="gone"
                android:textColor="@color/vertigo_alabaster_white"
                app:layout_collapseMode="parallax"/>

            <LinearLayout
                android:id="@+id/layout_button_bar"
                android:layout_width="match_parent"
                android:layout_height="@dimen/button_bar_height"
                android:layout_gravity="bottom"
                android:gravity="center_vertical"
                android:orientation="horizontal"
                android:background="@color/slide_handle">

                <!-- 3 Buttons -->

            </LinearLayout>

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

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

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recycler_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scrollbars="vertical"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

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

库:com.android.support:设计 23.0.1 |主题:Theme.AppCompat.NoActionBar

预崩:

中崩溃:

只需将类似 Button 和后续 Button 包裹在 Layout 中。例如 LinearLayout:

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="bottom"
            android:gravity="center_vertical"
            android:orientation="horizontal"
            android:layout_marginBottom="80dp"
            app:layout_collapseMode="parallax">


            <Button
                android:id="@+id/button_follow"
                ...
                />

            <Button
                android:id="@+id/button_like"
                ...
                />

        </LinearLayout>