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

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

フローティング アクション ボタン(FAB)とは、アプリの UI でメインとなる操作をトリガーする円形のボタンのことです。このドキュメントでは、レイアウトに FAB を追加する方法、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 属性によって決まります。この属性は、テーマのカラーパレットでカスタマイズできます。

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

  • 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 をご覧ください。