Настройка приложения: layout_behavior программно
У меня есть схема координатора с recyclerview, которую я хотел бы добавить программно. Причина, по которой она была добавлена программно, заключается в том, что различные фрагменты, которые раздувают компоновку координатора, могут использовать различные типы recyclerview.
Как правило, для recyclerview, чтобы установить это поведение, я бы добавил его в xml:
app:layout_behavior="@string/appbar_scrolling_view_behavior"
Это прекрасно работает. Тем не менее, я полностью потеряю, как добавить это поведение, когда я создаю recyclerviews программным путем, а затем добавляю их в framelayout:
<?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:layout_width="match_parent"
android:id="@+id/coordLayout"
android:layout_height="match_parent" android:fitsSystemWindows="true"
tools:context=".MainActivity">
<android.support.design.widget.AppBarLayout android:id="@+id/app_bar"
android:fitsSystemWindows="true" android:layout_height="@dimen/app_bar_height"
android:layout_width="match_parent" android:theme="@style/AppTheme.AppBarOverlay">
<android.support.design.widget.CollapsingToolbarLayout android:id="@+id/toolbar_layout"
android:fitsSystemWindows="true" android:layout_width="match_parent"
android:layout_height="match_parent" app:layout_scrollFlags="scroll|exitUntilCollapsed"
app:contentScrim="?attr/colorPrimary">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_height="?attr/actionBarSize"
android:layout_width="match_parent"
app:layout_collapseMode="pin"
app:popupTheme="@style/AppTheme.PopupOverlay" />
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<FrameLayout
android:id="@+id/frameLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content">
</FrameLayout>
</android.support.design.widget.CoordinatorLayout>
Ответы
Ответ 1
Behavior
является параметром CoordinatorLayout.LayoutParams
. Вы можете установить поведение в экземпляре CoordinatorLayout.LayoutParams
с помощью метода setBehavior
.
Чтобы получить правильный Behavior
объект, который представляет ту же самую вещь, что и @string/appbar_scrolling_view_behavior
, вы должны создать экземпляр AppBarLayout.ScrollingViewBehavior
.
Изменить 1:
У меня на самом деле нет примера, но я могу написать вам. Предположим, что у вас есть View
(например, yourView
), который уже прикреплен к CoordinatorLayout
(так что он уже имеет LayoutParams
).
CoordinatorLayout.LayoutParams params =
(CoordinatorLayout.LayoutParams) yourView.getLayoutParams();
params.setBehavior(new AppBarLayout.ScrollingViewBehavior());
yourView.requestLayout();
Вам может потребоваться немного настроить (я не тестировал это, но он должен работать).
Изменить 2:
Просто небольшая оговорка, потому что не все, кажется, прекрасно понимают этот пример.
yourView
, упомянутый в приведенном выше примере, НЕ сам CoordinatorLayout
. yourView
- CoordinatorLayout's
дочерний View
.
Ответ 2
Принятый ответ верен, но предоставленный код не подлежит компиляции. Итак, вот полный пример
CoordinatorLayout.LayoutParams params =
(CoordinatorLayout.LayoutParams) view.getLayoutParams();
params.setBehavior(новый AppBarLayout.ScrollingViewBehavior(view.getContext(), null));
2-й параметр - AttributeSet
, и это нормально, если он null
, хотя он не помечен как Nullable
в lib.