AppBarLayout は、垂直方向の LinearLayout であり、スクロールジェスチャーなど、Material Design のデザインガイドラインに従ったステータスバーが持つべき多くの機能を実装しています。
AppBarLayout は一般的に CoordinatorLayout の直接の子オブジェクトとして使用されますが、他のレイアウトで使用される場合、そのほとんどの機能が無効になります。AppBarLayout は、スクロールビューがいつスクロールするかを知るためのマーカーを必要とし、このマーカーのプロセスは AppBarLayout.ScrollingViewBehavior クラスをバインドすることによって完了します。これは、スクロールビューの動作を AppBarLayout.ScrollingViewBehavior のインスタンスに設定する必要があることを意味します。ここでは、完全なクラス名を含む文字列リソースを設定します。具体的には以下の通りです:
// layout_behavior 属性を設定
<android.support.v4.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
<!-- スクロールコンテンツ -->
</android.support.v4.widget.NestedScrollView>
AppBarLayout の子 View は、スクロール可能なビヘイビアを設定する必要があります。これはコードと xml 属性の両方で設定できます。具体的には以下の通りです:
// コード
setScrollFlags(int)
// xml 属性
app:layout_scrollFlags
layout_scrollFlags 属性は、AppBarLayout の子 View がスライドジェスチャーの変化に応じてどのような動作を実行するかを指定します。layout_scrollFlags 属性には 5 つの値があり、それぞれ次の通りです:
- scroll
- enterAlways
- enterAlwaysCollapsed
- exitUntilCollapsed
- snap
これらの属性値の効果を紹介する前に、以下のレイアウト効果を例にします。レイアウトは以下の通りです:
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.manu.materialdesignsamples.samples.SampleCoordinatorAppBarActivity">
<!-- AppBarLayout——>子Viewに layout_scrollFlags 属性を設定 -->
<android.support.design.widget.AppBarLayout
android:id="@+id/ablBar"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="70dp"
android:minHeight="?attr/actionBarSize"
app:layout_scrollFlags="scroll">
</android.support.v7.widget.Toolbar>
</android.support.design.widget.AppBarLayout>
<!-- NestedScrollView——>layout_behavior 属性を設定 -->
<android.support.v4.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
<android.support.v7.widget.RecyclerView
android:id="@+id/rvAppBarData"
android:clipToPadding="true"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
</android.support.v4.widget.NestedScrollView>
</android.support.design.widget.CoordinatorLayout>
scroll: layout_scrollFlags の属性を以下のように設定した場合:
app:layout_scrollFlags="scroll"
この時、上にスワイプすると最初に AppBarLayout が隠れ、その後にスクロールが始まります。下にスワイプすると、スクロールビューの上部に AppBarLayout が現れるまで表示されません。効果は以下の通りです:
enterAlways: enterAlways は scroll と一緒に使用する必要があります。layout_scrollFlags 属性を以下のように設定した場合:
app:layout_scrollFlags="scroll|enterAlways"
この時、上にスワイプすると最初に AppBarLayout が隠れ、その後にスクロールが始まります。下にスワイプすると最初に AppBarLayout が表示され、その後にスクロールが始まります。効果は以下の通りです:
enterAlwaysCollapsed: enterAlwaysCollapsed 属性値を使用する場合、scroll と enterAlways と一緒に使用する必要があります。また、AppBarLayout の子 View(ここでは Toolbar)に最小高さを設定して enterAlwaysCollapsed の機能をサポートする必要があります。layout_scrollFlags の属性を以下のように設定した場合:
app:layout_scrollFlags="scroll|enterAlways|enterAlwaysCollapsed"
この時、上にスワイプすると最初に AppBarLayout が隠れ、その後にスクロールが始まります。下にスワイプすると、AppBarLayout が最初に子 View の最小高さを表示し、その後にスクロールビューの上部に AppBarLayout が完全に表示されます。効果は以下の通りです:
exitUntilCollapsed: exitUntilCollapsed 属性値を使用する場合、scroll と一緒に使用する必要があります。また、AppBarLayout の子 View(ここでは Toolbar)に最小高さを設定して exitUntilCollapsed の機能をサポートする必要があります。layout_scrollFlags の属性を以下のように設定した場合:
app:layout_scrollFlags="scroll|exitUntilCollapsed"
この時、上にスワイプすると最初に AppBarLayout が最小高さまで隠れ、その後にスクロールが始まります。下にスワイプすると、スクロールビューの上部に AppBarLayout が現れるまで表示されません。効果は以下の通りです:
snap: snap 属性値を使用する場合、scroll と一緒に使用する必要があります。主な機能は、スクロールが終了したときに、伸縮するビューが部分的に表示されている場合、自動的に最近のエッジにスクロールすることです。layout_scrollFlags の属性を以下のように設定した場合:
app:layout_scrollFlags="scroll|snap"
この時、伸縮するビュー(ここでは Toolbar)が部分的に表示されている場合、伸縮するビューは最近のエッジに自動的にスクロールします。つまり、隠れるか表示されるかのいずれかです。効果は以下の通りです:
layout_scrollFlags 属性についての説明は以上です。もちろん、上記は属性値の効果を説明するためのものであり、CollapsingToolbarLayout などの他の Material Design と組み合わせてクールな効果を実現することもできます。上記はレイアウトファイルでの layout_scrollFlags 属性の設定です。ちなみに、コード内で layout_scrollFlags を設定する方法は以下の通りです:
AppBarLayout.LayoutParams params = (AppBarLayout.LayoutParams) appBarLayout
.getChildAt(0).getLayoutParams();
// 上にスワイプすると最初に AppBarLayout が隠れ、その後にスクロールが始まります。下にスワイプすると最初に AppBarLayout が表示され、その後にスクロールが始まります。
params.setScrollFlags(
AppBarLayout.LayoutParams.SCROLL_FLAG_SCROLL |
AppBarLayout.LayoutParams.SCROLL_FLAG_ENTER_ALWAYS);
//...
AppBarLayout の使用とその重要な属性については以上です。実際の開発ではもっと複雑になることが多いですが、上記の内容があなたの助けになることを願っています。皆さん、良い週末を!