Flutter3.16以降(Material3以降)はListTile#trailingにサイズ指定が必要に

このページには広告が含まれる場合があります。

 

2023年11月にFlutterのSDKのバージョンが3.16にアップデートされ、Flutterアプリを作る際に(性格にはMaterialAppで作る際に)使用するデフォルトのデザインガイドライン(Google先生が推奨するデザインガイドラインである「マテリアルデザイン」)のバージョンが「Material 2」から「Material 3」に変更されました。

blank

これによって、Flutterのバージョン3.16以前で作っていたプロジェクトを3.16にアップデート後にビルドすると、何もコードを変更していないのに見た目が変わってしまうという現象が起こってしまいますが、

リスト形式のデータを表示させるための便利なWidgetである「ListTile」の「trailing」属性(タイトルの後ろに表示させるWidget:以下画像ご参照)について、

blank

Flutter3.16未満では、空Containerを設置してもエラーにならなったのですが、Flutter3.16以降(Material3以降)では、

Trailing widget consumes entire tile width. Please use a sized widget, or consider replacing ListTile with a custom widget

というランタイムエラーが発生してしまいます。

blank

このエラーが発生した場合は、エラーメッセージに

Please use a sized widget, or consider replacing ListTile with a custom widget.
(サイズ指定されたWidgetを使うか、ListTileを別のカスタムWidgetに代えてください)

とあるように、trailingに設定するWidgetに以下のようにサイズを指定してやると解消します。

blank

(ちなみに、Iconはデフォルトでサイズが24.0に設定されているので、明示的に設定する必要はありません)

blank

なぜ、Flutter3.16未満(Material2以下)では大丈夫で、Flutter3.16以降(Material3以降)ではエラーになるのかは解明できていませんが、おそらく、エラーメッセージにAssertionで表示されている

tileWidth != trailingSize.width || tileWidth = 0.0

が新たに付与されたのではないかと思われます。

 

(詳しくは、以下の動画で説明していますので、よろしければご覧ください)

(注)以下のフォームより当社公式メールマガジンにご登録頂くことで
約6時間のFlutter動画講座が無料で受講できます!

(メールマガジンは登録無料・いつでも解除可)

[体験版]
ゼロからのFlutter
(Flutter初級編) 

 

【体験版講座に含まれるもの】
・約70本・約6時間の動画テキスト
・1つの課題アプリのソースコード
・Flutterアプリを作るための「環境構築ライブサポート(Google Meet)」
(「体験版」は全30時間超の「製品版」の約1/6を抜粋した講座です。「製品版」の詳細はこちらから)

 

【当社公式メルマガご登録6大特典】
blank

\約6時間動画講座を無料プレゼント!/
今すぐ無料体験版に申し込む ▶
無料メルマガ登録で講座割引クーポンなど6大特典ゲット!

こんな記事も読まれています

今すぐプレゼントを受け取る(約6時間のFlutter初級編体験版動画講座を無料でプレゼント)
blank

はじめての方へ

blank
みんプロ式プログラミング講座体系・ラインナップ
みんプロ式プログラミング講座受講の流れ(割引特典利用方法)
サイトマップ(みんプロHPコンテンツ一覧)
運営会社概要

みんプロ作成アプリ

blank
blank
blank
blank
blank

みんプロ式動画講座(コア・Flutter)

ゼロからのFlutter(初級編)-はじめてのプログラミングからアプリリリースまで-
Flutter中級編1-Web通信・設計・状態管理・DIの基礎-
Flutter中級編2-Firebase/地図・カメラ連携等の基礎-
Flutter中級編3-広告/アプリ内課金等の基礎-
Flutter中級編4-Webアプリとレスポンシブデザインの基礎-

みんプロ式動画講座(サテライト)

Flutter/Dartトラブルシューティング・小ネタ集(コア初級編受講で無料プレゼント)
ゼロからのGit・GitHub(コマンドラインツールを極力使わないバージョン管理入門)
Flutter/Dartにおける設計・状態管理・DIの解説集
Dart逆引き大辞典
Flutterにおけるテストの基礎
blank
blank

今すぐプレゼントを受け取る(約6時間のFlutter初級編体験版動画講座を無料でプレゼント)
TOP