こんばんは〜
弊社ブログに辿り着いていただきありがとうございます!
株式会社メモリアインクのいちのです
この記事を読んでわかること
- スクロールした際にヘッダーを非表示にする基本的な方法
- Flutterでのスクロールイベントの扱い方
- 状態管理の具体的な実装方法
開発環境
- Dart 3.0.0
- Flutter 3.10.0
スクロールした際にヘッダーを非表示にする方法
概要
FlutterではScrollController
を使用してスクロールイベントを検知し、そのイベントに応じてウィジェットの表示・非表示を切り替えることができます。以下のサンプルコードでは、スクロールを下に行った時にアプリバーを非表示にし、上にスクロールした時に再表示します。
サンプルコード
import 'package:flutter/material.dart';
import 'package:flutter/rendering.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: MyHomePage(),
);
}
}
class MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
late ScrollController _scrollController; // スクロールのコントローラーを定義
bool _isAppBarVisible = true; // アプリバーの表示状態を管理する変数
@override
void initState() {
super.initState();
_scrollController = ScrollController(); // スクロールコントローラーの初期化
_scrollController.addListener(_scrollListener); // スクロールイベントにリスナーを追加
}
@override
void dispose() {
_scrollController.removeListener(_scrollListener); // リスナーの削除
_scrollController.dispose(); // スクロールコントローラーの破棄
super.dispose();
}
void _scrollListener() { // スクロールイベントのリスナーメソッド
if (_scrollController.position.userScrollDirection == ScrollDirection.reverse) {
if (_isAppBarVisible) {
setState(() {
_isAppBarVisible = false; // 下にスクロール時、アプリバーを非表示にする
});
}
} else {
if (!_isAppBarVisible) {
setState(() {
_isAppBarVisible = true; // 上にスクロール時、アプリバーを表示する
});
}
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: _isAppBarVisible ? AppBar(title: Text('スクロールで隠れるアプリバー')) : null,
body: ListView.builder(
controller: _scrollController, // ListViewにスクロールコントローラーを設定
itemCount: 100,
itemBuilder: (context, index) => ListTile(
title: Text('アイテム $index'), // リストアイテムの表示
),
),
);
}
}
サンプルコードの解説
- 21行目:
ScrollController
オブジェクトを遅延初期化しています。これはスクロールイベントを管理するために必要です。 - 25-29行目:
initState
メソッド内で_scrollController
を初期化し、_scrollListener
メソッドをリスナーとして追加します。これにより、スクロールイベントが発生するたびに_scrollListener
が呼び出されます。 - 32-36行目:
dispose
メソッドでリスナーを削除し、_scrollController
を破棄します。これはリソースのリークを防ぐために重要です。 - 38-52行目:
_scrollListener
メソッドでは、スクロールの方向をチェックし、アプリバーの表示・非表示を切り替えるための状態を更新しています。 - 56-65行目:
Scaffold
のappBar
プロパティに条件付きでアプリバーを設定し、ListView.builder
を使用してリストを表示しています。スクロールコントローラーはListView
に関連付けられており、ユーザーのスクロール操作をトラッキングします。
動作確認
それでは、動作を確認してみましょ〜
ヘッダーメニュータブについてもご興味のある読者様。以下の記事で分かりやすく丁寧に解説しておりますので、ぜひご一読いただけますと幸いです。
まとめ
いかがでしたでしょうか?今回は、スクロールした際ヘッダーを非表示にする方法について、サンプルコードを用いて解説してみました。読者様の開発の手助けに少しでもなればいいなと思いこの記事を書かせていただいております。弊社ではAndroid、iOS、Flutterを使ったアプリ開発についてのブログを多数投稿させていただいておりますので、ご興味のある方はぜひ!
自分の成長を加速させるチャンスがどこかにあるかもしれません。
変化を恐れずに新たな環境に飛び込む勇気のある方は、
未経験からIT・Webエンジニアを目指すなら【ユニゾンキャリア】
スクロールした際、フッターメニュータブを非表示にする方法にもご興味のある読者様。以下の記事で分かりやすく丁寧に解説しておりますので、ぜひご一読いただけますと幸いです。
コメント
コメント一覧 (2件)
[…] 【Flutter】スクロールした際ヘッダーを非表示にする方法について解説 […]
[…] 【Flutter】スクロールした際ヘッダーを非表示にする方法について解説 […]