MaterialDesign3から塗りつぶしボタン(FilledButton
)と外枠ボタン(OutlinedButton
)が標準装備されたみたいなので使ってみました。
【Flutter】FilledButton と OutlinedButton
事前設定
MaterialApp
のtheme: ThemeData()
でuseMaterial3: true
を指定してMaterialDesign3を適用します。
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
useMaterial3: true,
primarySwatch: Colors.blue,
),
home: const MyHomePage(),
);
}
}
FilledButton
シンプルなパターン
data:image/s3,"s3://crabby-images/e8c67/e8c676b57980003de0f0e29326eb2b2dbcaef348" alt=""
FilledButton(onPressed: () {}, child: const Text('ログイン'))
アイコン付き
data:image/s3,"s3://crabby-images/65810/658109228be52c2fc941788b7f92b8e2cc4b3436" alt=""
FilledButton.icon(onPressed: () {}, icon: const Icon(Icons.login), label: const Text('ログイン'))
文字と背景の色反転
data:image/s3,"s3://crabby-images/d9a2c/d9a2cb6b3e6928359e971074d841e0ed24a13811" alt=""
FilledButton.tonal(onPressed: () {}, child: const Text('次へ'))
OutlinedButton
シンプルなパターン
data:image/s3,"s3://crabby-images/359e4/359e4fed7ed170086da117db1227c3b831125a9b" alt=""
OutlinedButton(onPressed: () {}, child: const Text('戻る'))
アイコン付き
data:image/s3,"s3://crabby-images/70234/702345047bd5b10f48c985260f74f1b5e1b8026e" alt=""
OutlinedButton.icon(onPressed: () {}, icon: const Icon(Icons.arrow_back), label: const Text('戻る'))
親Widgetの横幅いっぱいに表示する
ボタンの横幅はchild
の幅に依存するため、親Widgetの横幅いっぱいに表示したい場合はSizedBox
で包んでwidth
にdouble.infinity
を指定しましょう。
data:image/s3,"s3://crabby-images/55d33/55d33a2ffbf0f9fa882f8d5ae828b21644d27fda" alt=""
SizedBox(
width: double.infinity,
child: FilledButton(onPressed: () {}, child: const Text('親Widgetの幅いっぱい')),
)
以上
コメントを残す