7

Я пытаюсь реализовать макет с CollapsingToolbarLayout внутри DrawerLayout. Весь acitivty_main.xml выглядит следующим образом:Пробел ниже КоординаторLayout в DrawerLayout

<android.support.v4.widget.DrawerLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:id="@+id/activity_main__drawer_layout" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 

    <!-- The CoordinatorLayout is used to coordinate (rly) scroll events between different views --> 
    <android.support.design.widget.CoordinatorLayout 
     android:layout_width="match_parent" 
     android:layout_height="match_parent"> 

     <!-- The AppBar (everything above the scrolling content) --> 
     <android.support.design.widget.AppBarLayout 
      android:layout_height="wrap_content" 
      android:layout_width="match_parent" 
      android:id="@+id/activity_main__app_bar" 
      android:fitsSystemWindows="true" 
      app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 

      <android.support.design.widget.CollapsingToolbarLayout 
       android:id="@+id/activity_main__collapsing_toolbar" 
       android:layout_width="match_parent" 
       android:layout_height="@dimen/appbar_size_expanded" 
       android:minHeight="?attr/actionBarSize" 
       app:expandedTitleMarginEnd="16dp" 
       app:expandedTitleMarginStart="72dp" 
       app:expandedTitleMarginBottom="32dp" 
       app:expandedTitleTextAppearance="@style/ExpandedAppBarTitle" 
       app:contentScrim="?attr/colorPrimary" 
       app:layout_scrollFlags="scroll|exitUntilCollapsed"> 

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

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

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

     <!-- The scrolling content view --> 
     <android.support.v4.widget.NestedScrollView 
      android:id="@+id/activity_main__content_layout" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:background="#CCC333" 
      app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 

     <!-- The add button --> 
     <android.support.design.widget.FloatingActionButton 
      android:id="@+id/activity_main__floating_action_button" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_margin="16dp" 
      android:src="@drawable/ic_add_white_24dp" 
      android:clickable="true" 
      app:layout_anchor="@+id/activity_main__app_bar" 
      app:layout_anchorGravity="bottom|right|end" 
      app:borderWidth="0dp" 
      app:elevation="@dimen/fab_elevation" /> 

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

    <!-- The navigation drawer --> 
    <android.support.design.widget.NavigationView 
     android:id="@+id/activity_main__navigation_view" 
     android:layout_width="wrap_content" 
     android:layout_height="match_parent" 
     android:layout_gravity="start" 
     android:background="@android:color/white" 
     app:menu="@menu/menu_drawer" 
     app:headerLayout="@layout/drawer_navigation_header" /> 

</android.support.v4.widget.DrawerLayout> 

расположение и структура приложения свободно основана на this tutorial by codepath, где я изменил FrameLayout для NestedScrollView (даже если эффект появляется с обоими).

Теперь вид я намерен использовать для фактического содержания имеют некоторые странные отступы (я использовал цвет фона, чтобы выяснить, где он на самом деле оказывается):

device capture

Где я запутался?

ответ

2

Где я испортил?

Это ошибка библиотеки дизайна. Макеты «короче», чем высота экрана, вызывают зазоры, неправильное поведение при развале/разворачивании <CollapsingToolbarLayout> (т. Е. Вам нужно перетащить за пределами обрушившейся области, чтобы развернуть ее снова и т. Д. И т. Д. И т. Д. Это сейчас просто багги или пишется этот ответ (это, мы надеемся быть исправлены некоторые день, но я не получил никакой подсказки, когда это случится)

+0

ли есть ли предлагаемый способ обхода? Может быть, мой подкласс - это «LinearLayout» 'с' layout_height = "match_parent" 'и внутри него' TextView' с тем же, я не понимаю, как он короче высоты экрана. – heyarne

-1

попытаться удалить:. exitUntilCollapsed

в CollapsingToolbarlayout у вас есть теперь этот код

app:layout_scrollFlags="scroll"