FlutterのSimpleDialog
ウィジェットの用途と使い方のまとめ記事です。
本記事ではSimpleDialog
のサンプルコードを使いながら基本的な使い方、知っておきたい基本プロパティを解説していきます。
SimpleDialogとは?
SimpleDialog
は複数のオプション選択が可能なダイアログを(ポップアップウィンドウ)を表示できるウィジェットです。
SimpleDialogの基本的な使い方
SimpleDialog
はshowDialog()
を実行して表示できます。(showDialog()
の書き方は下のサンプルコードを参照)SimpleDialog
のtitle
でダイアログのタイトル、children
のリストにオプション数だけSimpleDialogOption()
を追加します。SimpleDialogOption()
のchild
の引数に任意のウィジェット、onPressed
でオプションがタップされた場合の処理を指定できます。またNavigator.of(context).pop()
を実行することでダイアログを非表示できます。
showDialog(
context: context,
builder: (BuildContext context) {
return SimpleDialog(
title: Text("タイトル"),
children: [
SimpleDialogOption(
child: Text('オプション1'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション2'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション3'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
周囲の黒い部分をタップして閉じないようにする
SimpleDialog
はNavigator.of(context).pop()
以外にもアラートダイアログの周囲の黒い部分をタップして閉じることができます。
周囲の黒い部分をタップして閉じないようにするにはshowDialog()
のbarrierDismissible
の引数にfalse
を渡します。
showDialog(
barrierDismissible: false,
context: context,
builder: (BuildContext context) {
return SimpleDialog(
title: Text("タイトル"),
children: [
SimpleDialogOption(
child: Text('オプション1'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション2'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション3'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
SimpleDialogで知っておきたい基本プロパティ
プロパティ名 | 説明 |
---|---|
backgroundColor | ダイアログの背景色を指定 |
elevation | ダイアログの影の高さを調整 |
shape | ダイアログの形を指定 |
backgroundColor:ダイアログの背景色を指定
backgroundColor
の引数にColor
渡してアラートダイアログの背景色を指定できます。
SimpleDialog(
title: Text("タイトル"),
backgroundColor: Colors.yellow,
children: [
SimpleDialogOption(
child: Text('オプション1'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション2'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション3'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
)
アウトプット(左側)
data:image/s3,"s3://crabby-images/99676/99676b2fe3d0a2b42ade52a548c42ebcd0672568" alt=""
data:image/s3,"s3://crabby-images/f8ff1/f8ff12c06351fae36bfbdbc0f7e3fd0e5b782c47" alt=""
elevation:ダイアログの影の高さを調整
elevation
の引数にdouble値を渡して影の高さを調整できます。
SimpleDialog(
title: Text("タイトル"),
elevation: 5,
children: [
SimpleDialogOption(
child: Text('オプション1'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション2'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション3'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
アウトプット(左側)
data:image/s3,"s3://crabby-images/0dab3/0dab3ae18b8acc15d476e5398566a0783f26947a" alt=""
data:image/s3,"s3://crabby-images/f8ff1/f8ff12c06351fae36bfbdbc0f7e3fd0e5b782c47" alt=""
shape:ダイアログの形を指定
shape
の引数にRoundedRectangleBorder()
を渡して角丸の調整ができます。RoundedRectangleBorder()
>borderRadius
>BorderRadius.circular()
の引数にdouble値を渡して角丸を調整します。
SimpleDialog(
title: Text("タイトル"),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(20),
),
children: [
SimpleDialogOption(
child: Text('オプション1'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション2'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション3'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
)
アウトプット(左側)
data:image/s3,"s3://crabby-images/be50a/be50aa90cf037408709a73d5b8862d77c562fbd0" alt=""
data:image/s3,"s3://crabby-images/f8ff1/f8ff12c06351fae36bfbdbc0f7e3fd0e5b782c47" alt=""
サンプルコード
import 'package:flutter/material.dart';
void main() => runApp(const MyApp());
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
home: Scaffold(
appBar: AppBar(title: const Text('Flutter')),
body: const SimpleDialogExample(),
),
);
}
}
class SimpleDialogExample extends StatefulWidget {
const SimpleDialogExample({super.key});
@override
State<SimpleDialogExample> createState() => _SimpleDialogExampleState();
}
class _SimpleDialogExampleState extends State<SimpleDialogExample> {
@override
Widget build(BuildContext context) {
return Center(
child: ElevatedButton(
child: Text('Show SimpleDialog'),
onPressed: () {
showDialog(
barrierDismissible: false,
context: context,
builder: (BuildContext context) {
return SimpleDialog(
title: Text("タイトル"),
elevation: 5,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(20),
),
children: [
SimpleDialogOption(
child: Text('オプション1'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション2'),
onPressed: () {
Navigator.of(context).pop();
},
),
SimpleDialogOption(
child: Text('オプション3'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
},
),
);
}
}
合わせて読みたい
data:image/s3,"s3://crabby-images/92a59/92a595fd33e4aac0cf7eba9d7e2cbc72479b1d1c" alt=""
data:image/s3,"s3://crabby-images/09061/090616ba5fbe8ab654b47bed4bbfa584635d7498" alt=""
data:image/s3,"s3://crabby-images/ef59b/ef59b5a815bf13e4cce77d561e44ed84a5d6e364" alt=""
参考サイト
- https://api.flutter.dev/flutter/material/AlertDialog-class.html
- https://www.youtube.com/watch?v=KPxq3SLjg98&ab_channel=HeyFlutter%E2%80%A4com