2

У меня есть поведение заголовка панели srange, которое, я сомневаюсь, что оно действительно.CollapsingToolbarLayout + TabLayout, странный заголовок заголовка панели инструментов

рухнул:

collapsed toolbar

продлен:

extended toolbar

Странная частью является то, что

приложение: titleMarginTop

не влияет на размещение титулов.

Вот мой Xml:

<?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:id="@+id/main_content" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:fitsSystemWindows="true" 
    tools:context="com.m360learning.app.activity.UserDetailsActivity"> 


    <android.support.design.widget.AppBarLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:fitsSystemWindows="true" 
     android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 

     <android.support.design.widget.CollapsingToolbarLayout 
      android:id="@+id/collapse_toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="250dp" 
      android:fitsSystemWindows="true" 
      app:contentScrim="?attr/colorPrimary" 
      app:layout_scrollFlags="scroll|exitUntilCollapsed"> 

      <RelativeLayout 
       android:layout_width="match_parent" 
       android:layout_height="match_parent" 
       android:fitsSystemWindows="true" 
       android:background="@drawable/background_navigation_drawer" 
       app:layout_collapseMode="parallax"> 
       <ImageView 
        android:id="@+id/header" 
        android:layout_width="match_parent" 
        android:layout_height="match_parent" 
        android:fitsSystemWindows="true" 
        android:scaleType="centerInside" /> 

      </RelativeLayout> 


      <android.support.v7.widget.Toolbar 
       android:id="@+id/toolbar" 
       android:layout_width="match_parent" 
       android:layout_height="100dp" 
       android:gravity="top" 
       android:minHeight="?attr/actionBarSize" 
       app:layout_collapseMode="pin" 
       app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 

       /> 

      <android.support.design.widget.TabLayout 
       android:id="@+id/tabs" 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       android:layout_gravity="bottom" 
       app:tabIndicatorColor="@color/colorAccent" /> 

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

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

    <android.support.v4.view.ViewPager 
     android:id="@+id/container" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 

    <android.support.design.widget.FloatingActionButton 
     android:id="@+id/fab" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_gravity="end|bottom" 
     android:layout_margin="@dimen/fab_margin" 
     android:src="@android:drawable/ic_dialog_email" /> 

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

Любая помощь будет принята с благодарностью. Благодаря

--- Edit: Если установить размер панели инструментов, чтобы "actionbarsize"

enter image description here

И это не меняет расширенное поведение.

------------ FINAL EDIT - КОРРЕКЦИЯ

<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:fitsSystemWindows="true"> 

    <android.support.design.widget.AppBarLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:fitsSystemWindows="true" 
     android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 

     <android.support.design.widget.CollapsingToolbarLayout 
      android:id="@+id/collapse_toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="250dp" 
      android:fitsSystemWindows="true" 
      app:contentScrim="?attr/colorPrimary" 
      app:layout_scrollFlags="scroll|exitUntilCollapsed"> 

      <RelativeLayout 
       android:layout_width="match_parent" 
       android:layout_height="match_parent" 
       android:background="@drawable/background_navigation_drawer" 
       android:fitsSystemWindows="true" 
       android:paddingBottom="?attr/actionBarSize" 
       android:paddingEnd="30dp" 
       android:paddingLeft="30dp" 
       android:paddingRight="30dp" 
       android:paddingStart="30dp" 
       app:layout_collapseMode="parallax"> 

       ...... 


      </RelativeLayout> 

      <android.support.v7.widget.Toolbar 
       android:id="@+id/toolbar" 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       android:gravity="top" 
       android:minHeight="?attr/actionBarSize" 
       app:layout_collapseMode="pin" 
       app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
       app:titleMarginTop="15dp" /> 



     </android.support.design.widget.CollapsingToolbarLayout> 
     <android.support.design.widget.TabLayout 
      android:id="@+id/tabs" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      android:layout_gravity="bottom" 
      android:background="?attr/colorPrimary" 
      app:tabGravity="fill" 
      app:tabIndicatorColor="#99FFFFFF" 
      app:tabIndicatorHeight="6dp" 
      app:tabMode="fixed" /> 

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

    <android.support.v4.view.ViewPager 
     android:id="@+id/container" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 


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

Почему вы не устанавливаете высоту панели инструментов как '? Attr/actionBarSize'? – adnbsr

+0

, если я это сделаю, когда панель инструментов разрушит отображение tabBar поверх нее, а не ниже –

+0

Используйте вкладки внутри collapsingToolbar, а панель инструментов должна быть приведена в действие bararsize вместо – adnbsr

ответ

5

Я думаю, что ваш TabLayout должен быть за пределами вашей CollapsingToolbarLayout в то же время внутри AppBarLayout:

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

    <android.support.design.widget.TabLayout 
     android:id="@+id/tabs" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     app:tabIndicatorColor="@color/colorAccent" /> 

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

Раздел вкладки является частью панели приложений, но не часть панели инструментов.

+0

Ницца! Я был уверен, что я попробовал это. Я обновляю свой xml –

+0

, если бы вы случайно знали, как уменьшить границу ниже заголовка при расширении панели инструментов? –

+0

Не из рук в руки. Стиль TextView на панели инструментов может существовать, но я не смог найти его в Theme.AppCompat. Единственное, что я мог предложить, это называть «setSupportActionBar()» на панели инструментов, а затем вызывать 'setCustomView()' на панели действий, чтобы настроить TextView, где вы можете управлять полями и вертикальным выравниванием. Я рекомендую опубликовать еще один вопрос и оставить сообщество SO в нем. –

3

@kris larson ответ в порядке, но, к сожалению, не работает, если мы хотим прозрачный parallaxed TabLayout фон. Для того, чтобы сделать его работу вам нужно сделать следующее:

  • добавить expandedTitleMarginBottom к CollapsingToolbarLayout
  • установить layout_height в TabLayout в качестве постоянной величины
  • добавить layout_marginBottom к Toolbar с таким же значением, как TabLayout высоты
<android.support.design.widget.AppBarLayout 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content"> 

    <android.support.design.widget.CollapsingToolbarLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     app:expandedTitleMarginBottom="56dp" 
     app:layout_scrollFlags="scroll|exitUntilCollapsed"> 

     <YourMagicViewWithBackgroundImageTextAndOtherStuff 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      app:layout_collapseMode="parallax" /> 

     <android.support.v7.widget.Toolbar 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_marginBottom="48dp" 
      app:layout_collapseMode="pin" /> 

     <android.support.design.widget.TabLayout 
      android:layout_width="match_parent" 
      android:layout_height="48dp" 
      android:layout_gravity="bottom" /> 

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