はじめに
今回はFlutterで使えるボタンウィジェットの種類を紹介していきます。
FlutterのMaterial3では従来のTextButtonやElevatedButtonに加えて、FilledButtonが新たに追加されました。
FlutterでMaterial3を適用させるには以下のコードを追加します。
useMaterial3: true
<コード例>
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
theme: ThemeData(
// falseにすると旧テーマカラーに戻ります
useMaterial3: true,
),
ボタンデザイン一覧
TextButton (輪郭や塗りつぶしの色のないボタン)
data:image/s3,"s3://crabby-images/3e427/3e4279d8b5d7b1cea5fad1334ceec3ef2741cda6" alt=""
TextButton(
onPressed: () {},
child: const Text('TextButton')),
OutlinedButton (枠線付きボタン)
data:image/s3,"s3://crabby-images/4927d/4927d799c8fca26e5cf4cf20eb0582cbfdbd25e3" alt=""
OutlinedButton(
onPressed: () {},
child: const Text('OutlinedButton')),
ElevatedButton (立体的な効果を持ったボタン)
data:image/s3,"s3://crabby-images/4da62/4da628ea506f2486cdd75054af479d337010b9a5" alt=""
ElevatedButton(
onPressed: () {},
child: const Text('ElevatedButton')),
FloatingActionButton (円形のアイコンボタン)
data:image/s3,"s3://crabby-images/922cb/922cbd9a52d1124f7bef9fed446a046a84c2a619" alt=""
FloatingActionButton(
onPressed: () {},
child: const Icon(Icons.add),),
色付きボタン
data:image/s3,"s3://crabby-images/8d084/8d084c647716072503864978cf30db437d74190c" alt=""
ElevatedButton(
style: ElevatedButton.styleFrom(
backgroundColor: Colors.amber,
foregroundColor: Colors.white,
),
onPressed: () {},
child: const Text('色付きボタン'),
),
🆕 FilledButton (塗りつぶしボタン)
data:image/s3,"s3://crabby-images/e25af/e25afc9abaa1a86039373b8715d7a5c5ad65ff6c" alt=""
FilledButton(
onPressed: () {},
child: const Text('塗りつぶしボタン')),
🆕 FilledButton.tonal (塗りつぶしボタンの色反転)
data:image/s3,"s3://crabby-images/34e10/34e101b7d06c6d94f1fe1589a6d05909f9fa28fa" alt=""
FilledButton.tonal(
onPressed: () {},
child: const Text('塗りつぶしボタンの色反転')),
🆕 FilledButton.icon (アイコン付きボタン)
data:image/s3,"s3://crabby-images/65559/655592bed4bde67d6b83c011115a2a2a359820d8" alt=""
FilledButton.icon(
onPressed: () {},
icon: const Icon(Icons.shopping_cart),
label: const Text('アイコン付きボタン')),
🆕 FilledButton.tonalIcon (アイコン付きボタンの色反転)
data:image/s3,"s3://crabby-images/fbed2/fbed2cd32a02ebc8ba85971856bf12d7656738ba" alt=""
FilledButton.tonalIcon(
onPressed: () {},
icon: const Icon(Icons.shopping_cart),
label: const Text('アイコン付きボタンの色反転')),
まとめ
いかがだったでしょうか?
UIデザインは日々アップデートしているのでこの機会に学んでみてはいかがでしょうか。
ご意見、ご感想ありましたらお気軽にコメントしてください。
【Material Designについてはコチラ】
data:image/s3,"s3://crabby-images/fb4c0/fb4c06dc4e36cb9b93eaef5bd31085ae009542b9" alt=""
Material Design
Build beautiful, usable products faster. Material Design is an adaptable system—backed by open-source code—that helps te...
コメント