AppBarLayout с recyclerView во вложенном фрагменте

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

Панель инструментов / вкладки находится в файле activity.xml с viewPager, а recyclerView находится внутри фрагмента в viewPager. Таким образом, вы можете прокручивать вправо / влево, чтобы увидеть другой контент.

Моя проблема в том, что я хочу, чтобы AppBarLayout был привязан в своем прокручиваемом поведении к recyclerView в первом фрагменте, но не к другим фрагментам.

В приведенном ниже коде я выполнил эту привязку, но это не работает, потому что recyclerView не распознает AppBarLayout во внешнем макете. У вас есть обходное решение для этого?

Код для деятельности:

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:fab="http://schemas.android.com/apk/res-auto" 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.support.v7.widget.Toolbar android:id="@+id/toolbar_main" android:layout_width="match_parent" /* pretty stuff */ app:layout_scrollFlags="scroll|enterAlways"> <android.support.design.widget.TabLayout android:id="@+id/tabs" android:layout_width="match_parent" android:layout_height="wrap_content" /* pretty stuff */ /> </android.support.v7.widget.Toolbar> </android.support.design.widget.AppBarLayout> <android.support.v4.view.ViewPager android:id="@+id/main_pager" android:layout_width="match_parent" android:layout_height="match_parent" /> <android.support.design.widget.SupportFloatingActionsMenu ...> /* Code for a fancy fab w/ menu */ </android.support.design.widget.SupportFloatingActionsMenu> </android.support.design.widget.CoordinatorLayout> 

Для фрагмента, содержащего recyclerView:

 <android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.insa.burnd.view.MainActivity.NewsfeedFragment" android:id="@+id/fragment_newsfeed"> <android.support.v4.widget.SwipeRefreshLayout android:id="@+id/swipe_layout" android:layout_width="match_parent" android:layout_height="wrap_content" app:layout_behavior="@string/appbar_scrolling_view_behavior"> <android.support.v7.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> </android.support.v4.widget.SwipeRefreshLayout> </android.support.design.widget.CoordinatorLayout> 

Большое спасибо 🙂 !

Solutions Collecting From Web of "AppBarLayout с recyclerView во вложенном фрагменте"

Вы можете сделать это, реализовав ViewPager.OnPageChangeListener и включив / отключив AppBarLayout.LayoutParams прокрутки AppBarLayout.LayoutParams .

Вот пример кода:

  viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { if (position == 0) { //turn on scrolling AppBarLayout.LayoutParams toolbarLayoutParams = (AppBarLayout.LayoutParams) mToolbar.getLayoutParams(); toolbarLayoutParams.setScrollFlags(AppBarLayout.LayoutParams.SCROLL_FLAG_SCROLL | AppBarLayout.LayoutParams.SCROLL_FLAG_ENTER_ALWAYS); mToolbar.setLayoutParams(toolbarLayoutParams); CoordinatorLayout.LayoutParams appBarLayoutParams = (CoordinatorLayout.LayoutParams) appBarLayout.getLayoutParams(); appBarLayoutParams.setBehavior(new AppBarLayout.Behavior()); appBarLayout.setLayoutParams(appBarLayoutParams); } else { //turn off scrolling AppBarLayout.LayoutParams toolbarLayoutParams = (AppBarLayout.LayoutParams) mToolbar.getLayoutParams(); toolbarLayoutParams.setScrollFlags(0); mToolbar.setLayoutParams(toolbarLayoutParams); CoordinatorLayout.LayoutParams appBarLayoutParams = (CoordinatorLayout.LayoutParams) appBarLayout.getLayoutParams(); appBarLayoutParams.setBehavior(null); appBarLayout.setLayoutParams(appBarLayoutParams); } } @Override public void onPageScrollStateChanged(int state) { } }); 

Но это не похоже на хороший образец UX. Это будет путать для пользователей.

Что со всеми сумасшедшими кодами / макетами?

Во фрагментах, где вы не хотите, чтобы панель инструментов прокручивалась, сделайте это в onCreateView() :

  recyclerView.setNestedScrollingEnabled(false); 

Я думаю, что ключом к решению вашей проблемы является удаление Coordinatorlayout из макета просмотра ресайклеров.

Это acitivity_main.xml, надутый MainActivity, с макетом-заполнителем, который включает

 <?xml version="1.0" encoding="utf-8"?> <android.support.v4.widget.DrawerLayout 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/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent" android:fitsSystemWindows="true" tools:openDrawer="start"> <include layout="@layout/app_bar_main" android:layout_width="match_parent" android:layout_height="match_parent" /> <android.support.design.widget.NavigationView android:id="@+id/nav_view" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_gravity="start" app:itemIconTint="@color/drawer_item" app:itemTextColor="@color/drawer_item" android:fitsSystemWindows="true" app:headerLayout="@layout/nav_header_main" app:menu="@menu/activity_main_drawer" /> </android.support.v4.widget.DrawerLayout>