CoordinatorLayout с использованием ViewPager RecyclerView
Я использую представление CoordinatorLayout
от android.support.design
. Я хочу привязать app:layout_behavior
к фрагменту RecyclerView
?
В примере, представленном Google, они прикрепляют его только к RecyclerView
того же файла XML, где был прикреплен CoordinatorLayout
.
Есть ли способ привязать CoordinatorLayout
к фрагменту RecyclerView
в пределах ViewPager
?
Образец находится в этом сообщении в блоге в блоге разработчиков Android.
Ответы
Ответ 1
Крис Банес опубликовал образец на Github, который показывает, что именно вы хотите сделать.
Вот xml файл, который определяет, как можно косвенно присоединить расположение координатора к фрагментам просмотра.
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
app:layout_scrollFlags="scroll|enterAlways" />
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</android.support.design.widget.AppBarLayout>
<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.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="@drawable/ic_done" />
</android.support.design.widget.CoordinatorLayout>
Идея состоит в том, чтобы позволить viewpager иметь атрибут layout_behavior.
Ответ 2
Это может быть немым, но это не сработало из-за того, что инструмент сборки не был обновлен в build.gradle
версии приложения до 22, я использовал 21, поэтому он не работает должным образом быть.
Edit:
И что сказал SanderTuit: добавление com.android.support:recyclerview-v7:22.2.0
также решит проблему
Ответ 3
Используйте FrameLayout и вставьте фрагмент в этот FrameLayout. Затем установите app: layout_behavior к нему. Единственное, что вам нужно сделать, это установить layout_behavior
к брату из AppBayLayout, и что брат будет ниже панели инструментов.
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
app:layout_scrollFlags="scroll|enterAlways" />
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</android.support.design.widget.AppBarLayout>
<FrameLayout
android:id="@+id/frame"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior" />
</android.support.design.widget.CoordinatorLayout>
Ответ 4
Недавно у меня была такая же проблема, о которой упоминалось в сообщении, и вышеупомянутые решения не сработали для меня. К счастью, мне удалось это решить. Итак, просто чтобы поделиться, я размещаю здесь
Проблема заключалась в том, что в моем коде я установил
recyclerView.setNestedScrollingEnabled(false);
из-за которого панель приложений не реагировала на свитки recyclerView, несмотря на то, что атрибут layout_behaviour для viewPager был установлен. Изменение вышеупомянутого атрибута на
recyclerView.setNestedScrollingEnabled(true);
решил проблему, и панель приложений начала реагировать на прокрутку recylerView.
Ответ 5
После нескольких тестов я обнаружил, что класть TabLayout за пределы AppBarLayout, будет работать, независимо от того, что содержит фрагмент Viewpager Fragment. Это мой основной xml.
<com.tqmall.legend.konwledge.view.VerticalSwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/swipe_refreshLayout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.CoordinatorLayout
android:id="@+id/coordinator_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#FFE6ECF0">
<android.support.design.widget.AppBarLayout
android:id="@+id/kn_main_appbar"
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:contentScrim="@android:color/black"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<include
layout="@layout/banner_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_collapseMode="parallax"
app:layout_collapseParallaxMultiplier="0.9" />
<android.support.v7.widget.Toolbar
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:layout_gravity="bottom"
android:background="#33000000"
app:layout_collapseMode="parallax"
app:layout_collapseParallaxMultiplier="0"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light">
</android.support.v7.widget.Toolbar>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
<android.support.design.widget.TabLayout
android:id="@+id/main_fragment_issue_list_tab"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
app:tabGravity="center"
app:tabIndicatorColor="#FF2CA2D5"
app:tabPaddingEnd="30sp"
app:tabPaddingStart="30sp"
app:tabSelectedTextColor="#FF2CA2D5"
app:tabTextColor="#FF4F5354" />
<android.support.v4.view.ViewPager
android:id="@+id/main_fragment_issue_list_pager"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
Ответ 6
У меня такая же проблема, я решил прокрутку, но поместил панель инструментов и вкладки внутри панели приложений и обернул ее, а viewpager - с координатором.
Также в макете моего вида обработки (для накачивания) я добавляю layout_behavior. Это работает, но проблема в том, что все друг над другом.
Это моя главная страница
<android.support.design.widget.CoordinatorLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_above="@+id/music_foot"
>
<android.support.v4.view.ViewPager
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/view_pager"
/>
<view
android:layout_width="match_parent"
android:layout_height="wrap_content"
class="android.support.design.widget.AppBarLayout"
android:id="@+id/appBar"
>
<android.support.v7.widget.Toolbar
android:layout_width="match_parent"
android:layout_height="56dp"
android:background="#1e88e5"
android:id="@+id/toolbar"
app:layout_scrollFlags="scroll|enterAlways"
></android.support.v7.widget.Toolbar>
<view
android:layout_width="match_parent"
android:layout_height="56dp"
class="com.astuetz.PagerSlidingTabStrip"
android:id="@+id/pager_tabs"
android:layout_below="@+id/appBar"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true" />
</view>
и это мой макет для адаптера
<android.support.v7.widget.RecyclerView
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"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:id="@+id/recycleView" />
Если я заставлю его работать лучше, расскажите.