フローティング操作ボタンを追加する

Compose を試す
Jetpack Compose は Android で推奨される UI ツールキットです。Compose でコンポーネントを追加する方法を学習します。

フローティング アクション ボタン(FAB)とは、アプリの UI でメインとなる操作をトリガーする円形のボタンのことです。このドキュメントでは、FAB をレイアウトに追加する方法、外観の一部をカスタマイズする方法、ボタンタップに応答する方法について説明します。

マテリアル デザイン ガイドラインに沿ってアプリの FAB をデザインする方法について詳しくは、マテリアル デザイン FAB をご覧ください。

赤色の FloatingActionButton を含むアプリ画面を示す画像
図 1. フローティング アクション ボタン(FAB)。

レイアウトへのフローティング アクション ボタンの追加

次のコードは、FloatingActionButton がレイアウト ファイルにどのように表示されるかを示しています。

<com.google.android.material.floatingactionbutton.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="end|bottom"
        android:src="@drawable/ic_my_icon"
        android:contentDescription="@string/submit"
        android:layout_margin="16dp" />

デフォルトでは、FAB は colorAccent 属性によって色付けされます。この属性は、テーマのカラーパレットでカスタマイズできます。

次のような XML 属性または対応するメソッドを使用して、他の FAB プロパティを設定できます。

  • FAB のサイズ(app:fabSize 属性または setSize() メソッドを使用)
  • FAB のリップルの色(app:rippleColor 属性または setRippleColor() メソッドを使用)
  • FAB アイコン(android:src 属性または setImageDrawable() メソッドを使用)

ボタンタップへの応答

その後、View.OnClickListener を適用して FAB のタップを処理できます。たとえば次のコードは、ユーザーが FAB をタップしたときに Snackbar を表示します。

Kotlin

val fab: View = findViewById(R.id.fab)
fab.setOnClickListener { view ->
    Snackbar.make(view, "Here's a Snackbar", Snackbar.LENGTH_LONG)
            .setAction("Action", null)
            .show()
}

Java

FloatingActionButton fab = findViewById(R.id.fab);
fab.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {
        Snackbar.make(view, "Here's a Snackbar", Snackbar.LENGTH_LONG)
                .setAction("Action", null).show();
    }
});

FAB の機能の詳細については、API リファレンスの FloatingActionButton をご覧ください。