奇怪的CoordinatorLayout / AppBarLayout行为

时间:2016-12-24 22:41:05

标签: android android-coordinatorlayout android-collapsingtoolbarlayout android-appbarlayout

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

    <android.support.design.widget.AppBarLayout
        android:id="@+id/app_bar"
        android:layout_width="match_parent"
        android:layout_height="200dp">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/toolbar_layout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:minHeight="100dp"
            app:contentScrim="?attr/colorPrimary"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">
        </android.support.design.widget.CollapsingToolbarLayout>
    </android.support.design.widget.AppBarLayout>

    <View
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:background="@color/colorAccent"
        app:layout_anchor="@id/app_bar"
        app:layout_anchorGravity="bottom"/>

    <include layout="@layout/content_scrolling"/>
</android.support.design.widget.CoordinatorLayout>

看起来,一旦CollapsingToolbarLayout达到minHeight高度,AppBarLayout就会变成“ontop”视图。请参见屏幕截图:

问题1 :为什么会这样?

问题2 :是否有可能阻止这种情况?我需要将方块放在顶部,同时将CollapsingToolbarLayout折叠到其最小高度。

1 个答案:

答案 0 :(得分:0)

<强>锚

我认为您的问题的原因是 AppBarLayout 的锚点和高度属性。我建议做什么:

  • height AppBarLayout 属性设置为 wrap_content

  • max_height heightCollapsingToolbarLayout 设置为200dp

  • View 的锚点设置为 CollapsingToolbarLayout

老实说,我希望自己有所帮助,我对Android仍然很陌生,但如果我已经知道了,请告诉我。 -Daniel