Android Design Support libraryを使う (4)FloatingActionButton,CoordinatorLayout
Android Design Support libraryはAndroid Support Library 22.2で公開された、
マテリアルデザインを実現するのに便利なコンポーネントのライブラリです。
そんなDesign Support libraryのコンポーネントの紹介と使い方の説明をしていきたいと思います。
導入方法は第一回のこちらから。
本稿ではFloatingActionButtonとCoordinatorLayoutの使い方を紹介します。
FloatingActionButton
Androidのマテリアルデザインと聞くとFloatingActionButtonが浮かぶ人も多いのではないでしょうか。レイアウト上に配置するだけでOKなので使い方も非常に簡単です。
acitivty_main.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout 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="jp.techpjin.coordinatorlayoutsample.MainActivity"> <android.support.design.widget.FloatingActionButton android:id="@+id/floating_action_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_alignParentRight="true" android:layout_marginBottom="16dp" android:layout_marginRight="16dp" android:src="@drawable/plus" app:borderWidth="0dp"/> </RelativeLayout>
CoordinatorLayout
CoordinatorLayoutはFrameLayoutを機能拡張したようなコンポーネントで、ひとつ以上の子Viewの間に相互関係を持たせることのできるレイアウトです。
まずは簡単な例としてFloatingActionButtonとの組み合わせを考えます。
FloatingActionButtonが下部にあるときSnackbarを表示すると次のように重なって表示されてしまいます。
そこでレイアウトを次のように変更します。
activity_main.xml
<?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" android:id="@+id/coordinator_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.design.widget.FloatingActionButton android:id="@+id/floating_action_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginBottom="16dp" android:layout_marginRight="16dp" android:src="@drawable/plus" app:borderWidth="0dp" app:layout_anchor="@id/coordinator_layout" app:layout_anchorGravity="bottom|right" /> </android.support.design.widget.CoordinatorLayout>
ポイントは、
・FloatingActionButtonをCoordinatorLayoutの子Viewとして配置すること
・「アンカー」設定すること
です。
app:layout_anchorで紐付けるViewを指定することで、対象のViewの位置やサイズの変更を受け取ることができるようになります。
app:layout_anchorGravityでViewの配置場所を指定します。
MainAcitivity.java
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); final CoordinatorLayout coordinatorLayout = (CoordinatorLayout)findViewById(R.id.coordinator_layout); FloatingActionButton floatingActionButton = (FloatingActionButton)findViewById(R.id.floating_action_button); floatingActionButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Snackbar.make(coordinatorLayout, "Snackbar", Snackbar.LENGTH_LONG).show(); } }); } }
Snackbarの親ViewとしてCoordinatorLayoutを指定しています。
以上によりFloatingActionButtonとSnackbarの間に関係を持たせることが出来、次のような挙動になります。
FloatingActionButtonとCoordinatorLayoutの使い方について紹介しました。
CoordinatorLayoutを用いることでリストのスクロールに合わせてバーやタブが動くといった挙動(GooglePlayのアプリをイメージしてください)も実装できるのですがそれについては次回説明したいと思います。