CollapsingToolbarLayout и TabLayout

Опитвам се да създам дейност, която има CollapsingToolbarLayout с изображение и лента с инструменти (като в CheeseDetailActivity в примера на cheesesquare тук), който също има оформление на раздели по-долу.

Някакви идеи как да го приложа?

Когато се опитвате да го добавите към CollapsingToolbarLayout или AppBarLayout, резултатът е, че оформлението на раздела е в горната част на екрана


person Roi Divon    schedule 03.06.2015    source източник


Отговори (2)


Опитайте тази структура:

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

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

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="SPECIFIC HEIGHT HERE!"
        android:fitsSystemWindows="true"
        android:theme="ADD A STYLE HERE IF YOU WANT">

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

            <ImageView
                android:id="@+id/backdrop"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:fitsSystemWindows="true"
                android:scaleType="centerCrop"
                android:src="YOUR SOURCE"
                app:layout_collapseMode="parallax"
                app:layout_collapseParallaxMultiplier="YOUR MULTIPLIER"
                />

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:popupTheme="YOUR POPUP THEME">

            </android.support.v7.widget.Toolbar>

            <android.support.design.widget.TabLayout
                android:id="@+id/tabs"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_gravity="bottom"
                app:tabGravity="YOUR TAB GRAVITY"
                app:tabIndicatorColor="YOUR TAB INDICATOR COLOR"
                app:tabMode="YOUR TAB MODE">

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

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

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

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

Важният атрибут е layout_gravity на TabLayout да бъде отдолу.

За API 21 и по-ниски се сблъсках с проблема с изчезването на TabLayout. Ако се сблъскате със същия проблем, за TabLayout (за API под 21) използвайте това:

<android.support.design.widget.TabLayout
    android:id="@+id/tabs"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:fitsSystemWindows="true"
    android:translationY="YOU HAVE TO EXPERIMENT WITH THIS ATTRIBUTE - (in dps)"
    app:tabGravity="YOUR TAB GRAVITY"
    app:tabIndicatorColor="YOUR TAB INDICATOR COLOR"
    app:tabMode="YOUR TAB MODE"
    >

Трябва да експериментирате с атрибута translationY в зависимост от размера, който сте дали на лентата на приложението си. Ще въведете стойност в dps и след няколко минути ще я заковате.

Надявам се, че работи за вас, както работи за мен!

person TheoK    schedule 03.06.2015
comment
Добавих ViewPager в примера, защото а) е необходим за TabLayout и б) ще приеме layout_behavior=@string/appbar_scrolling_view_behavior - person TheoK; 03.06.2015
comment
Хей, накарахте ли това да работи с фиксирани раздели, които имат гравитационно запълване? Имам само два раздела и искам те да запълнят цялата ширина, но те винаги ще се показват центрирани, като ширината се определя от най-дългия етикет... Някакви мисли за това? - person Tim Strehlow; 05.06.2015
comment
Нямах време да експериментирам повече. Веднага след като го потърся, ще се свържа с вас, ако имам резултати - person TheoK; 05.06.2015
comment
как можете да поставите tablayout под лентата за действие? - person Yang Peiyong; 13.06.2015
comment
@PeiyongYang можеш ли да публикуваш връзка към макет, за да разбереш какво искаш да постигнеш? - person TheoK; 13.06.2015
comment
Може ли поведението на това оформление да бъде променено по начин, така че когато превъртам нагоре, оформлението на раздела да остане под лентата с инструменти? drive.google.com/file/d/0B3twBzbq00qfdW82TWZaRWJER2c/ ето екрана на това, което искам да постигна. В тази ситуация не искам да мога да превъртам разделите повече нагоре, само за да ги запазя в тази позиция. - person Lubos Mudrak; 24.07.2015
comment
@XOOLOOO опитайте да промените layout_scrollFlags - person TheoK; 25.07.2015
comment
@LubosMudrak Намерихте ли защо да разрешите това? Не ми харесва много идеята за translationY - person Tanasis; 24.11.2018

Вижте също този пример, който разглежда същия проблем.

Тестван по API 14-23. Работи без проблеми.

person Vito Valov    schedule 30.09.2015
comment
Благодаря, прекарах много време, за да намеря работещо решение, точно това ми трябва. - person Georgy Gobozov; 16.11.2015