今回は、FlutterとDartでAppbarを使っていこうと思います。
アプリのヘッダーを作りたい方などはAppbarが必須かなと思いますのでぜひ参考にしてみてください!
学習に使った本はこちら!
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
Amazon Kindle Unlimited でもFlutter、Dartの本はいっぱいあるぞ!
もし、まだFlutterとDartの環境構築をしていない方やシュミレータの起動方法がわからない方は、
「FlutterとDartの開発環境構築をしよう!」を参考にしてみてください!
data:image/s3,"s3://crabby-images/8526e/8526e3728070cc388672498793ad4defe4acf4c5" alt=""
data:image/s3,"s3://crabby-images/8526e/8526e3728070cc388672498793ad4defe4acf4c5" alt=""
今回やること!
Basicsで紹介されている初めてFlutterアプリを作る前に絶対に知っておきたいWidgetの内、Appbarを実際に実装して紹介していきます。
最終的には、Twitterっぽいヘッダーを作ってみようと思います。
Twitterっぽいヘッダーを作る際にタブなどを利用しますが、説明は省かせてもらいます。
Appbarの使い方を紹介!
では実際に、Appbarの使い方を説明していきます!
Appbarを使ってみる!
では、早速Appbarを実装してみましょう!
Appbarを実装する前は、こんな感じにしておきます!
data:image/s3,"s3://crabby-images/04395/043958c51791a471ceb7f5a8cd3e8e2a1ee829c6" alt=""
data:image/s3,"s3://crabby-images/04395/043958c51791a471ceb7f5a8cd3e8e2a1ee829c6" alt=""
import 'package:flutter/material.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key? key, required this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Text(
'Teech Lab.',
style: TextStyle(fontSize: 50),
),
),
);
}
}
ここにAppbarを実装してみます!
import 'package:flutter/material.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key? key, required this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('Teech Lab.'),
),
body: Center(
child: Text(
'Teech Lab.',
style: TextStyle(fontSize: 50),
),
),
);
}
}
実行するとこんな感じで、上部にバーが表示されたと思います。
data:image/s3,"s3://crabby-images/81dbf/81dbf22544f8fb239356edb7bc63e01de8d2a782" alt=""
data:image/s3,"s3://crabby-images/81dbf/81dbf22544f8fb239356edb7bc63e01de8d2a782" alt=""
Appbarにアイコンボタンを表示してみる!
続いては、先ほど実装したAppbarにアイコンボタンを表示してみようと思います!
今回はアンドロイド(Icons.android_outlined)を表示してみました。。。笑
import 'package:flutter/material.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key? key, required this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('Teech Lab.'),
actions: <Widget>[
IconButton(
icon: const Icon(Icons.android_outlined),
onPressed: () {
},
)
]
),
body: Center(
child: Text(
'Teech Lab.',
style: TextStyle(fontSize: 50),
),
),
);
}
}
どうでしょうか、アンドロイドがのぞいていますね。
こんな感じでIconButtonなどをおくことで、ホームボタンやメニューボタンを設定することができます!
data:image/s3,"s3://crabby-images/b3124/b3124c7b558868c1c9b14dd4a417d0195d00578d" alt=""
data:image/s3,"s3://crabby-images/b3124/b3124c7b558868c1c9b14dd4a417d0195d00578d" alt=""
Twitterっぽいヘッダーを作ってみる!
それではAppbarにIconButtonを表示して、Twitter風のヘッダーを作ってみましょう!
FlutterのAppbarは、下記の図のように設定することができます。
どこに何を配置するか意識するだけで、ある程度形になるので便利ですね。
data:image/s3,"s3://crabby-images/b5af0/b5af0f39247cdb8742db7412112a64d442c98d98" alt="The leading widget is in the top left, the actions are in the top right,
the title is between them. The bottom is, naturally, at the bottom, and the
flexibleSpace is behind all of them."
data:image/s3,"s3://crabby-images/b5af0/b5af0f39247cdb8742db7412112a64d442c98d98" alt="The leading widget is in the top left, the actions are in the top right,
the title is between them. The bottom is, naturally, at the bottom, and the
flexibleSpace is behind all of them."
今回はTwitterっぽいヘッダーにするために、以下の通りに設定します。
- leadingにメニューアイコンを設定
- actionsにキラキラアイコンを設定
- bottomにタブとテキストを設定
- 背景色は白、ボタンやテキストはライトブルーに設定
実装は、こんな感じになります。
buttomにタブを使う場合、タブコントローラー(今回は、DefaultTabController)が必要になりますので注意してください。
import 'package:flutter/material.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key? key, required this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return DefaultTabController(
length: 2,
child: Scaffold(
appBar: AppBar(
leading: IconButton(
icon: const Icon(Icons.menu),
color: Colors.lightBlue,
onPressed: () {
},
),
title: const Text(
'Teech Lab.',
style: TextStyle(
color: Colors.lightBlue
),
),
actions: <Widget>[
IconButton(
icon: const Icon(Icons.star),
color: Colors.lightBlue,
onPressed: () {
},
)
],
bottom: const TabBar(
labelColor: Colors.lightBlue,
unselectedLabelColor: Colors.grey,
tabs: <Tab>[
Tab(text: 'Home'),
Tab(text: 'teech lab.')
],
),
backgroundColor: Colors.white,
),
body: Center(
child: Text(
'Teech Lab.',
style: TextStyle(fontSize: 50),
),
),
),
);
}
}
実行するとこんな感じです!
キラキラに違和感がありますが、ある程度の再現はできたのではないでしょうか笑
data:image/s3,"s3://crabby-images/ca2a2/ca2a29b81a743fbae3ab8ab59a5c32ab4bdd31ed" alt=""
data:image/s3,"s3://crabby-images/ca2a2/ca2a29b81a743fbae3ab8ab59a5c32ab4bdd31ed" alt=""
まとめ
今回は、タブやアイコンボックスについては詳しく説明していませんので、各自で調べてみてください。
学習に使った本はこちら!
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
Amazon Kindle Unlimited でもFlutter、Dartの本はいっぱいあるぞ!
Appbarを使うことで簡単にHeaderを作ることができるので、ぜひ参考にしてみてください!
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
参考にしてくれると嬉しいぞ!