Fultterでタブで画面を切り替える方法を紹介します。
画面をタブで整理するなら、DefaultTabController
、TabBar
、TabBarView
を使うのが最適です。
また、記事の後半でTabController
を使うパターンも紹介しています。
まずはDefaultTabController
でタブを表示するページを囲みます。
そしてlength
プロパティにタブの数を設定します。これは必須です。
home: DefaultTabController(
length: 3,
child: Scaffold(
appBar: AppBar(
title: const Text('タブ画面移動サンプル'),
),
),
),
次にTabBar
を使って、ユーザーが画面の切り替えに使うタブを設定します。
TabBar
はTab
のリストを取得します。タブにはTextやアイコンなどを設定できます。
home: DefaultTabController(
length: 3,
child: Scaffold(
appBar: AppBar(
title: const Text('タブ画面移動サンプル'),
bottom: const TabBar(
tabs: <Widget>[
Tab(icon: Icon(Icons.cloud_outlined)),
Tab(icon: Icon(Icons.beach_access_sharp)),
Tab(icon: Icon(Icons.brightness_5_sharp)),
],
),
),
),
),
最後にTabBarView
を使って、各タブに対応するコンテンツを設定します。
TabBar
で設定したタブと1対1で対応させます。
今回はTextを表示させていますがここに別のページを設定することもできます。
home: DefaultTabController(
length: 3,
child: Scaffold(
appBar: AppBar(
title: const Text('タブ画面移動サンプル'),
bottom: const TabBar(
tabs: <Widget>[
Tab(icon: Icon(Icons.cloud_outlined)),
Tab(icon: Icon(Icons.beach_access_sharp)),
Tab(icon: Icon(Icons.brightness_5_sharp)),
],
),
),
body: const TabBarView(
children: <Widget>[
Center(child: Text('くもり', style: TextStyle(fontSize: 50))),
Center(child: Text('雨', style: TextStyle(fontSize: 50))),
Center(child: Text('晴れ', style: TextStyle(fontSize: 50))),
],
),
),
),
サンプルアプリのソースコードです。まずはこれをコピペして動かしてみてから中身を調べていくとわかりやすいと思います!
import 'package:flutter/material.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
Widget build(BuildContext context) {
return MaterialApp(
home: DefaultTabController(
length: 3,
child: Scaffold(
appBar: AppBar(
title: const Text('タブ画面移動サンプル'),
bottom: const TabBar(tabs: <Widget>[
Tab(icon: Icon(Icons.cloud_outlined)),
Tab(icon: Icon(Icons.beach_access_sharp)),
Tab(icon: Icon(Icons.brightness_5_sharp)),
]),
),
body: const TabBarView(
children: <Widget>[
Center(child: Text('くもり', style: TextStyle(fontSize: 50))),
Center(child: Text('雨', style: TextStyle(fontSize: 50))),
Center(child: Text('晴れ', style: TextStyle(fontSize: 50))),
],
),
),
),
);
}
}
タブはDefaultTabController
を使わないで実装することも可能です。
その場合DefaultTabController
の代わりにTabController
を使います。
以下では、同じサンプルアプリをTabController
を使って実装してみます。
Stateの部分を以下のように変更してTabController
のインスタンス_tabControllerを定義します。
class _MyHomePageState extends State<MyHomePage> with TickerProviderStateMixin {
late TabController _tabController;
void initState() {
super.initState();
_tabController = TabController(length: 3, vsync: this);
}
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('タブ画面移動サンプル'),
),
);
}
}
次にTabBar
を使って、ユーザーが画面の切り替えに使うタブを設定します。
ここでやっていることは、このページの前半で説明したDefaultTabController
を使うパターンの②とほぼ同じです。
controller
プロパティに①で定義した_tabControllerを設定するところだけ違うので注意してください。
return Scaffold(
appBar: AppBar(
title: const Text('タブ画面移動サンプル'),
bottom: TabBar(
controller: _tabController,
tabs: const <Widget>[
Tab(icon: Icon(Icons.cloud_outlined)),
Tab(icon: Icon(Icons.beach_access_sharp)),
Tab(icon: Icon(Icons.brightness_5_sharp)),
],
),
),
);
最後にTabBarView
を使って、各タブに対応するコンテンツを設定します。
やっていることは、このページの前半で説明したDefaultTabController
を使うパターンの③とほぼ同じです。
ここでもcontroller
プロパティに①で作った_tabControllerを設定します。
return Scaffold(
appBar: AppBar(
title: const Text('タブ画面移動サンプル'),
bottom: TabBar(
controller: _tabController,
tabs: const <Widget>[
Tab(icon: Icon(Icons.cloud_outlined)),
Tab(icon: Icon(Icons.beach_access_sharp)),
Tab(icon: Icon(Icons.brightness_5_sharp)),
],
),
),
body: TabBarView(
controller: _tabController,
children: const <Widget>[
Center(child: Text('くもり', style: TextStyle(fontSize: 50))),
Center(child: Text('雨', style: TextStyle(fontSize: 50))),
Center(child: Text('晴れ', style: TextStyle(fontSize: 50))),
],
),
);
import 'package:flutter/material.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
Widget build(BuildContext context) {
return const MaterialApp(
home: MyHomePage(),
);
}
}
class MyHomePage extends StatefulWidget {
const MyHomePage({Key? key}) : super(key: key);
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> with TickerProviderStateMixin {
late TabController _tabController;
void initState() {
super.initState();
_tabController = TabController(length: 3, vsync: this);
}
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('タブ画面移動サンプル'),
bottom: TabBar(
controller: _tabController,
tabs: const <Widget>[
Tab(icon: Icon(Icons.cloud_outlined)),
Tab(icon: Icon(Icons.beach_access_sharp)),
Tab(icon: Icon(Icons.brightness_5_sharp)),
],
),
),
body: TabBarView(
controller: _tabController,
children: const <Widget>[
Center(child: Text('くもり', style: TextStyle(fontSize: 50))),
Center(child: Text('雨', style: TextStyle(fontSize: 50))),
Center(child: Text('晴れ', style: TextStyle(fontSize: 50))),
],
),
);
}
}
いかがでしたでしょうか。
タブの利用は奥が深く細かいカスタマイズが可能ですが、本記事では核となる最低限の使い方だけを紹介しました。
参考にしていただけたら幸いです。
https://api.flutter.dev/flutter/material/DefaultTabController-class.html https://api.flutter.dev/flutter/material/TabBar-class.html
可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。
Read More可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。
Read More