質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

解決済

switch文の画面遷移でエラーが出てしまう。

JohnWall
JohnWall

総合スコア1

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

2回答

0リアクション

0クリップ

374閲覧

投稿2022/07/16 08:01

編集2022/07/16 15:00

こんにちは、flutter初心者です。

BottomNavigationBarを遷移後の画面でも保持するため、
CupertinoTabBarを用いてswitch文で表示画面の切り替えをしたいと考えています。

しかし、以下のエラーが出てしまいビルドができない状態です。

Failed assertion: line 4531 pos 14: 'owner!._debugCurrentBuildTarget == this': is not true.

どのようにすれば、エラーなく画面遷移を行えますでしょうか?
皆さんのお知恵をお借りできましたら嬉しいです!

main.dart

import 'package:flutter/material.dart'; import 'package:test001/screens/home_screen.dart'; import 'package:test001/screens/menu_screen.dart'; import 'package:test001/screens/profile_screen.dart'; import 'models/routes.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); // This widget is the root of your application. @override Widget build(BuildContext context) { return MaterialApp( debugShowCheckedModeBanner: false, title: 'Myapp', theme: ThemeData( primarySwatch: Colors.yellow, textTheme: const TextTheme( titleLarge: TextStyle( fontSize: 20, color: Colors. white, fontWeight: FontWeight.w500, ) ) ), home: const HomeScreen(), ); } }

cupertino_bottom_navigation.dart

import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:test001/screens/home_screen.dart'; import 'package:test001/screens/menu_screen.dart'; import 'package:test001/screens/profile_screen.dart'; class BottomNavigation extends StatelessWidget { const BottomNavigation({ Key? key, }) : super(key: key); @override Widget build(BuildContext context) { return CupertinoTabScaffold( tabBar: CupertinoTabBar( items: const <BottomNavigationBarItem>[ BottomNavigationBarItem(icon: Icon(Icons.home), label: 'Home'), BottomNavigationBarItem(icon: Icon(Icons.menu), label: 'Menu'), BottomNavigationBarItem(icon: Icon(Icons.person), label: 'Profile'), ], ), tabBuilder: (BuildContext context, int index) { switch (index) { case 0: return CupertinoTabView( builder: (context) { return const CupertinoPageScaffold( child: HomeScreen(), ); }, ); case 1: return CupertinoTabView( builder: (context) { return const CupertinoPageScaffold( child: MenuScreen(), ); }, ); case 2: return CupertinoTabView(builder: (context) { return const CupertinoPageScaffold( child: ProfileScreen(), ); }); default: return CupertinoTabView( builder: (context) { return const CupertinoPageScaffold( child: HomeScreen(), ); }, ); } }); } }

home_screen.dart

import '../widgets/cupertino_bottom_navigation.dart'; import 'package:flutter/material.dart'; class HomeScreen extends StatefulWidget { const HomeScreen({Key? key}) : super(key: key); @override _HomeScreenState createState() => _HomeScreenState(); } class _HomeScreenState extends State<HomeScreen> { @override Widget build(BuildContext context) { return Scaffold( backgroundColor: Colors.yellow, appBar: AppBar( leading: const Icon(Icons.person), title: Text('Your Name'), ), bottomNavigationBar: const BottomNavigation()); } }

menu_screen.dart

import 'package:flutter/material.dart'; class MenuScreen extends StatefulWidget{ const MenuScreen ({ Key? key }) : super(key: key); @override _MenuState createState() => _MenuState(); } class _MenuState extends State<MenuScreen>{ @override Widget build(BuildContext context) => Scaffold( appBar:AppBar(title: Text('メニューページ'),), ); }

profile_screen.dart

import 'package:flutter/material.dart'; class ProfileScreen extends StatefulWidget{ const ProfileScreen({ Key? key }) : super(key: key); @override _ProfileState createState() => _ProfileState(); } class _ProfileState extends State<ProfileScreen>{ @override Widget build(BuildContext context) => Scaffold( appBar:AppBar(title: Text('プロフィールページ'),), ); }

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

JohnWall

2022/07/16 15:02

ta.fuさんにご指摘いただいた箇所の修正をさせていただきました。 しかし、以前として同じエラーメッセージが表示されている状態です。 全体のコードを記載していますので、もし怪しい箇所などありましたら教えてもらえますと助かります!

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。