AppBarLayout / CollapsingToolbarLayout бесконечно расширяется

Я пытаюсь использовать AppBarLayout + CollapsingToolbarLayout, чтобы иметь складную панель инструментов с изображением, которое исчезает при прокрутке вверх, но панель инструментов остается.

Проблема в том, что когда я устанавливаю AppBarLayout и CollapsingToolbarLayout android:layout_height = "wrap_content", панель инструментов заполняет весь экран. http://i.stack.imgur.com/be1m6.png

Когда я устанавливаю android:layout_height = "200dp", высота фиксируется, но она не работает с NestedScrollView и изменением размера. http://i.stack.imgur.com/MTao2.png

Вот 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/articleLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.gmail.senokt16.bosphoruschronicle.ArticleActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/articleCollapsingToolbar"
            android:layout_width="match_parent"
            android:layout_height="200dp"
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            app:toolbarId="@+id/article_app_bar">

            <ImageView
                android:id="@+id/articleActivityImage"
                android:layout_width="match_parent"
                android:layout_height="200dp"
                android:minHeight="100dp"
                app:layout_collapseMode="parallax"
                app:layout_collapseParallaxMultiplier="0.7"
                app:layout_scrollFlags="scroll|enterAlways|enterAlwaysCollapsed"
                android:fitsSystemWindows="true"/>

            <include
                android:id="@+id/article_app_bar"
                android:fitsSystemWindows="true"
                layout="@layout/article_app_bar" />
        </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"
        android:minHeight="300dp"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <TextView
            android:id="@+id/articleActivityContents"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:paddingBottom="30dp"
            android:paddingLeft="20dp"
            android:paddingRight="20dp"
            android:paddingTop="5dp" />
    </android.support.v4.widget.NestedScrollView>

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/articleFAB"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_alignParentRight="true"
        android:layout_margin="16dp"
        android:src="@android:drawable/ic_menu_share" />


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

comment
Здравствуйте, MrHappy. Я рекомендую вам взглянуть на этот отличный проект на GitHub github.com/chrisbanes/cheesesquare. является полным примером использования библиотеки дизайна поддержки Android, включая использование: Свертывание панели инструментов FloatingActionButton View привязка NavigationView Snackbar. Надеюсь, что это может помочь вам   -  person darkangelo    schedule 18.08.2015
comment
@darkangelo Я внес некоторые изменения на основе приведенного вами примера, и есть некоторые улучшения. Это похоже на второе изображение, но всякий раз, когда я прокручиваю до любого конца NestedScrollView, AppBarLayout перемещается как 10dp. Однако он по-прежнему не следует прокрутке должным образом. Я задам еще один вопрос, так как исходная проблема, кажется, несколько решена.   -  person MrHappy    schedule 18.08.2015


Ответы (2)


Это случилось и со мной.

Сначала я удалил <include> и добавил панель инструментов вручную.

Это все же произошло, поэтому после некоторых возни я обнаружил, что это происходит из-за того, что на моей панели инструментов было minimumHeight, но layout_height=wrap_content. Я изменил его на layout_height=?attr/actionbarsize, и это сработало. Вот мой пример. (В FrameLayout есть вложенный прокрутка, как у вас внутри.)

<android.support.design.widget.CoordinatorLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <android.support.design.widget.AppBarLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:fitsSystemWindows="true">

            <android.support.design.widget.CollapsingToolbarLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                app:contentScrim="?attr/colorPrimary"
                app:layout_scrollFlags="scroll|exitUntilCollapsed"
                app:titleEnabled="false">

                <ImageView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    app:layout_collapseMode="parallax"
                    android:src="@drawable/logo"
                    />

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

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

        <FrameLayout
            android:id="@+id/content_frame"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

    </android.support.design.widget.CoordinatorLayout>
person Jacques.S    schedule 01.06.2016

Я внес некоторые изменения в код и несколько исправил проблему. Теперь у меня другая проблема: CollapsingToolbarLayout и NestedScrollView не работают вместе

person MrHappy    schedule 19.08.2015