概要
このブログポストではFlutterで画面のレイアウトを担当するウィジェットについて詳しくみてみます。
このブログポストで紹介したソースコどーは下記のリンクで確認できます。
SafeArea
新しい携帯ではアプリ画面を最大利用できるようにデザインされます。iOSのノッチ(Notch)デザインやアンドロイドステータスバーなどアプリが表示されるエリアが拡大しております。
そのせいで、次のようにコードを作成すると、
@override
Widget build(BuildContext context) {
return Scaffold(
body: Text('Hello world'),
);
}
次のようにステータスバーの下にウィジェットが表示される問題が発生します。
data:image/s3,"s3://crabby-images/bef4d/bef4dc7eff7c2d1477a75803b712a5ddc4405e86" alt="Flutter - Before SafeArea widget"
この問題を解決するため、使えるウィジェットがSafeArea
です。SafeArea
は下記のように使えます。
@override
Widget build(BuildContext context) {
return Scaffold(
body: SafeArea(
child: Text('Hello world'),
),
);
}
このようにSafeArea
を使うと次のようにステータスバー以外のエリアにウィジェットが表示されます。
data:image/s3,"s3://crabby-images/453fe/453fef4ac2d79324c8b94159d043d5bdf64d9a9b" alt="Flutter - After SafeArea widget"
Center
Center
ウィジェットはチャイルドウィジェットを真ん中へ表示します。
@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Text('Hello world'),
),
);
}
このようにCenterウィジェットのチャイルドウィジェットにText
を渡すと、次のように真ん中に表示されることが確認できます。
data:image/s3,"s3://crabby-images/c0391/c0391f29ad5ea893a4fac3e5d5c45e0a1d4c5e3d" alt="Flutter - Center widget"
Padding
Padding
ウィジェットはチャイルドウィジェットにpadding
を表示します。
@override
Widget build(BuildContext context) {
return Scaffold(
body: Padding(
child: Text('Hello world'),
padding: EdgeInsets.fromLTRB(100.0, 300.0, 10.0, 40.0),
),
);
}
このようにPaddingウィジェットにチャイルドウィジェットを入れて、padding
の値を設定するとチャイルドウィジェットがPaddingと一緒に表示されます。
data:image/s3,"s3://crabby-images/5a48c/5a48c8381c8a9437c9ee9941809b104426ad37b0" alt="Flutter - Padding widget"
Container
Container
ウィジェットを使うと基本的最大の空間を占めて表示されます。
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Container'),
),
body: Container(
color: Colors.red,
),
);
}
このようにContainerを表示すると、次のように最大空間(画面の全て)に表示されます。
data:image/s3,"s3://crabby-images/e2e78/e2e780d23ac9ccf4a5a3a28b5e588180aa272ba1" alt="Flutter - Container widget with no option"
もし、Containerへチャイルドウィジェットがセットされると、Containerはチャイルドウィジェットのサイズで表示されます。
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Container'),
),
body: Container(
color: Colors.red,
child: Text(
'Hello world',
style: TextStyle(color: Colors.yellow),
),
),
);
}
このようにContainerにチャイルドウィジェットを指定すると次のようにContainerはチャイルドウィジェットのサイズで表示されます。
data:image/s3,"s3://crabby-images/a6a08/a6a08f1023c047bb6d221c99b35932fb37474130" alt="Flutter - Container widget with child"
ContainerはPadding
とは違って次のように色んなパラメータを使うことができます。
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Container'),
),
body: Container(
child: Text(
'Hello world',
style: TextStyle(color: Colors.red),
),
padding: EdgeInsets.fromLTRB(20.0, 30.0, 40.0, 50.0),
margin: EdgeInsets.all(100.0),
width: 200,
height: 100,
transform: Matrix4.rotationZ(0.5),
decoration: BoxDecoration(
color: Colors.yellow,
border: Border.all(color: Colors.black, width: 3),
borderRadius: BorderRadius.all(Radius.circular(18)),
boxShadow: const [
BoxShadow(blurRadius: 10),
],
),
),
);
}
このように色んなパラメータを使うと次のようにパラメータが適用されたContainerウィジェットが表示されます。
data:image/s3,"s3://crabby-images/04a37/04a370519fa63e58068362c3c72a5aa15599617b" alt="Flutter - Container widget with options"
ColumnとRow
Flutterで画面のレイアウトを作るとき一番使ってるColumn
ウィジェットとRow
ウィジェットについて説明します。
Column
Column
ウィジェットはチャイルドウィジェットを縦に並べて表示します。Columnウィジェットは縦の全てのエリアを占めて表示されます。
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column(
children: [
Container(
width: 100,
height: 100,
color: Colors.red,
),
Container(
width: 100,
height: 100,
color: Colors.yellow,
),
Container(
width: 100,
height: 100,
color: Colors.green,
),
],
),
);
}
上のようにColumnウィジェットはchildren
でもらったウィジェットを次のように縦で表示します。
data:image/s3,"s3://crabby-images/ee4a6/ee4a66c5a44851e1ae14ce013a99c23ab4afe343" alt="Flutter - Column widget"
ColumnのmainAxisAlignment
パラメータを使うと、チャイルドウィジェットの並び替えることができます。
- center
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width: 100,
height: 100,
color: Colors.red,
),
Container(
width: 100,
height: 100,
color: Colors.yellow,
),
Container(
width: 100,
height: 100,
color: Colors.green,
),
],
),
);
}
data:image/s3,"s3://crabby-images/b416b/b416bcf016e6d44d3b93d030ccaee4080e3b4edd" alt="Flutter - Column widget center"
- end
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column(
mainAxisAlignment: MainAxisAlignment.end,
children: [
Container(
width: 100,
height: 100,
color: Colors.red,
),
Container(
width: 100,
height: 100,
color: Colors.yellow,
),
Container(
width: 100,
height: 100,
color: Colors.green,
),
],
),
);
}
data:image/s3,"s3://crabby-images/41598/41598a7b127a08ef982b641cd60a4e59c326cc60" alt="Flutter - Column widget end"
- spaceAround
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column(
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: [
Container(
width: 100,
height: 100,
color: Colors.red,
),
Container(
width: 100,
height: 100,
color: Colors.yellow,
),
Container(
width: 100,
height: 100,
color: Colors.green,
),
],
),
);
}
data:image/s3,"s3://crabby-images/0b5ff/0b5ffb435029a5a26c67a8954612d43f87a9d5a5" alt="Flutter - Column widget spaceAround"
Row
Row
ウィジェットはチャイルウィジェットを横に並べて表示します。Rowウィジェットは横のエリアを占めて表示されます。
@override
Widget build(BuildContext context) {
return Scaffold(
body: Row(
children: [
Container(
width: 100,
height: 100,
color: Colors.red,
),
Container(
width: 100,
height: 100,
color: Colors.yellow,
),
Container(
width: 100,
height: 100,
color: Colors.green,
),
],
),
);
}
上のようにRowウィジェットはchildren
でもらったウィジェットを次のように横に表示します。
data:image/s3,"s3://crabby-images/2ce75/2ce756838a729b800429d3976693ee8503be92c8" alt="Flutter - Row widget"
RowのmainAxisAlignment
パラメータを使うと、チャイルドウィジェットを並び替えることができます。
- center
@override
Widget build(BuildContext context) {
return Scaffold(
body: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width: 100,
height: 100,
color: Colors.red,
),
Container(
width: 100,
height: 100,
color: Colors.yellow,
),
Container(
width: 100,
height: 100,
color: Colors.green,
),
],
),
);
}
data:image/s3,"s3://crabby-images/722ad/722ade98d768e4dda15eb5dfe6ba9d34d03a285e" alt="Flutter - Row widget center"
- end
@override
Widget build(BuildContext context) {
return Scaffold(
body: Row(
mainAxisAlignment: MainAxisAlignment.end,
children: [
Container(
width: 100,
height: 100,
color: Colors.red,
),
Container(
width: 100,
height: 100,
color: Colors.yellow,
),
Container(
width: 100,
height: 100,
color: Colors.green,
),
],
),
);
}
data:image/s3,"s3://crabby-images/cb622/cb6226dae8acc40448beb116d1ae6bcdb0ae0bd3" alt="Flutter - Row widget end"
- spaceAround
@override
Widget build(BuildContext context) {
return Scaffold(
body: Row(
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: [
Container(
width: 100,
height: 100,
color: Colors.red,
),
Container(
width: 100,
height: 100,
color: Colors.yellow,
),
Container(
width: 100,
height: 100,
color: Colors.green,
),
],
),
);
}
data:image/s3,"s3://crabby-images/dc9f1/dc9f19c00e1fb1f6616f02b79128d2175ec975d6" alt="Flutter - Row widget spaceAround"
Expanded
Expanded
ウィジェットはColumn
ウィジェットまたはRow
ウィジェットと一緒に使うとウェブ開発で使えるflex
と同じ機能を実装することができます。
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column(
children: [
Expanded(
child: Container(
color: Colors.red,
),
flex: 3,
),
Expanded(
child: Container(
color: Colors.yellow,
),
flex: 1,
),
Expanded(
child: Container(
color: Colors.green,
),
flex: 2,
),
],
),
);
}
上のようにColumnウィジェットのチャイルドウィジェットでExpandedウィジェットを使って、Expandedウィジェットのflex
パラメータを使うと次のようにウェブで使えるflex
と同じ機能を実装することができます。
data:image/s3,"s3://crabby-images/8f23c/8f23cb7ec5c924501e02859e43340ba001c1c5be" alt="Flutter - Expanded widget"
Stack
Stack
ウィジェットを使うと、ウィジェットの上にウィジェットを表示することができます。
@override
Widget build(BuildContext context) {
return Scaffold(
body: Stack(
children: [
Container(
width: 400,
height: 400,
color: Colors.green,
),
Container(
width: 200,
height: 200,
color: Colors.yellow,
),
Container(
width: 50,
height: 50,
color: Colors.red,
),
],
),
);
}
上のようにStackウィジェットを使うと、次のようにウィジェットの上にウィジェットを表示することができます。
data:image/s3,"s3://crabby-images/d4750/d4750460358e24e55bcb8b59ae0a6bec43e68c44" alt="Flutter - Stack widget"
SizedBox
SizedBox
ウィジェットはウィジェットとウィジェットの間に空きスペースを入れる時、よく使えます。
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column(
children: [
Container(
color: Colors.red,
width: 100,
height: 100,
),
SizedBox(
height: 200,
),
Container(
color: Colors.yellow,
width: 100,
height: 100,
),
SizedBox(
height: 50,
),
Container(
color: Colors.green,
width: 100,
height: 100,
),
],
),
);
}
上のようにContainerウィジェットとウィジェットの間にSizedBoxウィジェットを追加すると下記のように空きスペースが追加されることが確認できます。
data:image/s3,"s3://crabby-images/51d36/51d36d59f671a7a4e047ff27585ddc74fcd6e5de" alt="Flutter - SizedBox widget"
完了
これでFlutterでよく使えるレイアウト関連ウィジェットをみてみました。今からはこのウィジェットを使って色んなレイアウトを構成してみてください。
私のブログが役に立ちましたか?下にコメントを残してください。それは私にとって大きな大きな力になります!
アプリ広報
Deku
が開発したアプリを使ってみてください。Deku
が開発したアプリはFlutterで開発されています。興味がある方はアプリをダウンロードしてアプリを使ってくれると本当に助かります。