PageViewを使ってFlutterで画像を複数の画面上で共通化する方法

image

画像を保持したまま画面遷移をしたいって思ったことはないですか?? ちょうどこの間その処理をする機会が訪れたので、せっかくならということで、記事を作って投稿することにしました。 参考までにご覧ください。

方法の説明

まずは当たり前ですが、通常通り、画像をFlutterに取り込み、Flutterで表示させる2つの画面のコードを書きます。 次に、共通画面ページを作成します。 この際に、Pgae ViewというWidgetを使用します。 PageView は画面をスワイプして遷移させる Widgetです。 通常はボタンを使用して画面遷移をさせると思うんですが、PageViewWidgetを使用することでスクロールだけで画面遷移をすることができるようになります。 スクロールで画面遷移をしているため、背景画像をずっと貼り続けたようなUIを作ることができます。語彙足らずで何言ってるかわかんないという人は下のGif画像でなんとなく把握してください。

GIF Animation

各画面での処理

ここからは各画面の設計方法を実際のコードを紹介しながら説明していきます。 まずはmain.dartです。

main.dart

MaterialApp(
      theme: ThemeData.dark(),
      home: ScreenImage(),
    );

常にbackgroundは透明にしておく必要があるので、Colors.transparentを入れておきます。 次に一番目の画面を作っていきます。

home_page.dart


return Scaffold(
      backgroundColor: Colors.transparent,
      body: Stack(
        fit: StackFit.expand,
        children: [
          Column(
            children: const [
              //この中に自由に表示させたい Widgteをぶち込んじゃってください。
              //今回は適当にTextを入れております。
              Text('data'),
              Text('data'),
              Text('data'),
              Text('data'),
              Text('data'),
            ],
          ),
        ],
      ),
    );

画像が常に後ろにある状態なので、Stackを必ず使用して画面を設計していってください。 2つ目の画面も同様にStackを用いて表示させます。

では最後に一番重要な画像を表示させるページを作成します。

screen_image

  PageController controller = PageController(initialPage: 0);
return Scaffold(
      backgroundColor: Colors.transparent,
      body: Stack(
        fit: StackFit.expand,
        children: [
          Image.asset(
            'assets/images/ikusa.jpg',
            fit: BoxFit.cover,
          ),
          PageView(
            controller: controller,
            children: [
              HomePage(),
              SettingPage()
            ],
          ),
        ],
      ),
    );

Image Image

これだと、どのサイトでも一般的に紹介している内容でしかないので、わざわざこの記事を見る意味はないですよね。 そう思って、今回はAppbarでボタンを活用して画面遷移をする方法も追記しておきます。

ボタンを使用して画面遷移

PageViewのスワイプ機能をボタンでも活用することができるんです。 方法は以下の通りです。 まず、各ページに PageControllerを渡してあげます。 次にAppbarを用いてleanding Buttonを作成します。 そして一つ目の画面にはnextPageを、二つ目の画面にはpreviousPageを渡してあげます。 最後に共通画面のPageViewにcontrollerを渡してあげて終わりです。

コードは以下の通りです。 各画面のbodyなどは特に変更ないので省略します。

home_page.dart

 required this.controller}),
  final PageController controller;

 appBar: AppBar(
        backgroundColor: Colors.transparent,
        leading: IconButton(
          onPressed: () {
            widget.controller.nextPage(
                duration: const Duration(milliseconds: 100),
                curve: Curves.bounceIn);
          },
          icon: const Icon(Icons.settings),
        ),
      ),

2つ目の画面は widget.controller.nextPageの部分を widget.controller.previousPageに変更するだけです。 最後に共通画面です。 screen_image


 HomePage(
                  controller: controller,
                ),
                SettingPage(
                  controller: controller,
                ),

このようにcontollerを渡してあげるだけです。

Image Image

終わりに

どうです?うまくできましたか? 画面遷移の方法はこのほかにもBottom Navigation Barを利用した画面遷移など色々あります。 皆さんも適した画面遷移方法を使ってアプリを作成してみてください。

参考資料

PageView公式ドキュメント


https://api.flutter.dev/flutter/widgets/PageView-class.html

お知らせ

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More
U30可茂ITインターンハッカソン

U30可茂ITインターンハッカソン

12月28,29日開催。2日間でアプリ開発の企画から完成までを目指す!U30可茂ITインターンハッカソンを開催します。

Read More

タグ

Flutter (118)初心者向け (29)イベント (18)Google Apps Script (16)Nextjs (12)可茂IT塾 (10)React (8)Firebase (7)riverpod (6)ChatGPT (5)vscode (5)デザイン (5)新卒 (4)就活 (4)Figma (4)Dart (4)JavaScript (4)お知らせ (4)FlutterWeb (3)Prisma (3)NestJS (3)Slack (3)TypeScript (3)ワーケーション (3)インターン (3)設計 (2)線型計画法 (2)事例 (2)Git (2)Image (2)File (2)Material Design (2)経験談 (2)画像 (2)iOS (2)アプリ開発 (2)React Hooks (2)tailwindcss (2)社会人 (2)大学生 (2)RSS (1)Google (1)Web (1)CodeRunner (1)個人開発 (1)Android (1)Unity (1)WebView (1)Twitter (1)フルリモート (1)TextScaler (1)textScaleFactor (1)学生向け (1)supabase (1)Java (1)Spring Boot (1)shell script (1)正規表現 (1)table (1)テーブル (1)hooks (1)react (1)パワーポイント (1)趣味 (1)モンスターボール (1)CSS (1)SCSS (1)Cupertino (1)ListView (1)就活浪人 (1)既卒 (1)保守性 (1)iPad (1)シェアハウス (1)スクレイピング (1)PageView (1)画面遷移 (1)flutter_hooks (1)Gmail (1)GoogleWorkspace (1)ShaderMask (1)google map (1)Google Places API (1)GCPコンソール (1)Google_ML_Kit (1)Vercel (1)Google Domains (1)DeepLeaning (1)深層学習 (1)Google Colab (1)コード生成 (1)GitHub Copilot (1)オンラインオフィス (1)javascript (1)css (1)html (1)オブジェクト指向 (1)クラスの継承 (1)ポリモーフィズム (1)LINE (1)Bitcoin (1)bitFlyer (1)コミュニティー (1)文系エンジニア (1)build_runner (1)freezed (1)Freezed (1)ヒーター (1)作業効率 (1) (1)Flutter実践開発 (1) (1)permission_handler (1)flutter_local_notifications (1)markdown (1)GlobalKey (1)ValueKey (1)Key (1)アイコン (1)go_router (1)FireStorage (1)debug (1)datetime_picker (1)Apple Store Connect (1)FlutterGen (1)デバッグ (1)Widget Inspector (1)VRChat (1)API (1)検索機能 (1)Shader (1)Navigator (1)メール送信 (1)FlutterFlow (1)Firebase App Distribution (1)Fastlane (1)Dio (1)CustomClipper (1)ClipPath (1)カスタム認証 (1)アニメーション (1)Arduino (1)ESP32 (1)フリーランス (1)会社員 (1)mac (1)csv (1)docker (1)GithubActions (1)Dialog (1)BI (1)LifeHack (1)ショートカット (1)Chrome (1)高校生 (1)キャリア教育 (1)非同期処理 (1)生体認証 (1)BackdropFilter (1)レビュー (1)getAuth (1)クローズドテスト (1)PlayConsole (1)Algolia (1)コンサルティング (1)Symbol (1)

お知らせ

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More
U30可茂ITインターンハッカソン

U30可茂ITインターンハッカソン

12月28,29日開催。2日間でアプリ開発の企画から完成までを目指す!U30可茂ITインターンハッカソンを開催します。

Read More