フローティング アクション ボタン(FAB)は、ユーザーが操作できる高強調ボタンです。 メイン アクションを実行するアクションを指します。焦点を絞った単一のアクションを促進する これはユーザーがたどる最も一般的な経路で、 画面の右下に固定されます。
FAB を使用する 3 つのユースケースを考えてみましょう。
- 新しいアイテムを作成する: メモ作成アプリでは、FAB を使用して 新しいメモを作成します。
- 新しい連絡先の追加: チャットアプリでは、FAB から 会話にユーザーを追加できます。
- Center location: 地図インターフェースでは、FAB は地図の中心を ユーザーの現在地を確認できます
マテリアル デザインには、次の 4 種類の FAB があります。
- FAB: 通常サイズのフローティング アクション ボタン。
- 小 FAB: 小さいフローティング アクション ボタン。
- 大型 FAB: 大型のフローティング アクション ボタン。
- 拡張 FAB: 単なる アイコンをクリックします。
API サーフェス
フローティング アクションの作成に使用できるコンポーザブルはいくつかありますが、 ボタンはマテリアル デザインと一致しており、パラメータに大きな違いはありません。 留意すべき主なパラメータは次のとおりです。
onClick
: ユーザーがボタンを押すと呼び出される関数。containerColor
: ボタンの色。contentColor
: アイコンの色。
フローティング操作ボタン
一般的なフローティング アクション ボタンを作成するには、基本的な
FloatingActionButton
コンポーザブル。次の例は、
FAB の基本的な実装は次のとおりです。
@Composable fun Example(onClick: () -> Unit) { FloatingActionButton( onClick = { onClick() }, ) { Icon(Icons.Filled.Add, "Floating action button.") } }
これを実装すると次のようになります。
小さいボタン
小さいフローティング アクション ボタンを作成するには、
SmallFloatingActionButton
コンポーザブル。次の例は、
カスタムカラーを追加します。
@Composable fun SmallExample(onClick: () -> Unit) { SmallFloatingActionButton( onClick = { onClick() }, containerColor = MaterialTheme.colorScheme.secondaryContainer, contentColor = MaterialTheme.colorScheme.secondary ) { Icon(Icons.Filled.Add, "Small floating action button.") } }
これを実装すると次のようになります。
大きいボタン
大きなフローティング アクション ボタンを作成するには、
LargeFloatingActionButton
コンポーザブル。このコンポーザブルは
他の例とは大きく異なりますが
ボタンが大きくなります。
以下は、大きな FAB の簡単な実装です。
@Composable fun LargeExample(onClick: () -> Unit) { LargeFloatingActionButton( onClick = { onClick() }, shape = CircleShape, ) { Icon(Icons.Filled.Add, "Large floating action button") } }
これを実装すると次のようになります。
拡張ボタン
より複雑なフローティング アクション ボタンを作成するには、
ExtendedFloatingActionButton
コンポーザブル。主な違いは
FloatingActionButton
は専用の icon
と text
がある点です。
あります。より複雑なコンテンツのボタンを作成し、サイズに応じて調整できる
コンテンツを適切に適合させることができます
次のスニペットは、
ExtendedFloatingActionButton
。icon
に渡された値の例と
text
。
@Composable fun ExtendedExample(onClick: () -> Unit) { ExtendedFloatingActionButton( onClick = { onClick() }, icon = { Icon(Icons.Filled.Edit, "Extended floating action button.") }, text = { Text(text = "Extended FAB") }, ) }
これを実装すると次のようになります。