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

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

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

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

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

Q&A

解決済

1回答

3193閲覧

Flutterで非同期で格子状に画像とテキストを表示する方法

退会済みユーザー

退会済みユーザー

総合スコア0

Flutter

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

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

0グッド

0クリップ

投稿2020/03/18 11:57

Flutterド素人です。

Flutterでアプリを開発しており、以下画像のようなレイアウトを組みたいと考え、試行錯誤しております。
イメージ説明

画像に手書きしたとおり、格子状にタイルのようなものを配置し、そのタイルには画像とテキスト(画像中ではImageとTitleとしています)を(恐らくColumnで)配置します。タイルの数はFirestoreに登録したドキュメントの数分になります(登録した分だけ増えていく予定です)。

このようなレイアウトを考えている中で、以下のような実装を考えています。

  1. 格子状のレイアウトはGridView.builderで組む
  2. 各タイルはGridViewのitemBuilderに、Firestoreから取得した各ドキュメントから取り出したImage(String型のURLなのでHTTP Getが別途、必要)とTitle(String型)をContainerに配置して渡す

のような流れかと思うのですが、ググって調べてみると、Firestoreからドキュメントを取得してタイル状に表示する実装はStreamBuilderを使う方が良いようにも思え、また、StreamBuilderを使う場合、StreamBuilderで非同期に取得した各ドキュメントを随時、Containerに配置して表示し、且つ、Imageも非同期でgetするような処理が必要かと思いますが、私にはかなり複雑な処理に思え、実装が進んでいないのが現状です。

もしサンプル実装など踏まえ、部分的にでもご教示いただければ幸いです。
よろしくお願い致します。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

以下、自己解決したのでコードを掲載します。同様なことでお困りの方がいらっしゃれば参考にしてみてください。

dart

1 StreamBuilder( 2 stream: Firestore.instance.collection('books').snapshots(), 3 builder: (BuildContext context, 4 AsyncSnapshot<QuerySnapshot> snapshot) { 5 if (!snapshot.hasData) 6 return Center( 7 child: CircularProgressIndicator(), 8 ); 9 10 return GridView.builder( 11 gridDelegate: SliverGridDelegateWithFixedCrossAxisCount( 12 crossAxisCount: 2), 13 itemCount: snapshot.data.documents.length, 14 padding: EdgeInsets.all(2.0), 15 itemBuilder: (BuildContext context, int index) { 16 return Container( 17 child: GestureDetector( 18 onTap: () { 19 Navigator.of(context).pushNamed('/book_detail'); 20 }, 21 child: Column( 22 children: <Widget>[ 23 Image( 24 image: AdvancedNetworkImage( 25 snapshot.data.documents[index]['thumbnail'], 26 useDiskCache: true, 27 cacheRule: CacheRule( 28 maxAge: const Duration(days: 7)), 29 ), 30 fit: BoxFit.cover, 31 ), 32 Text(snapshot.data.documents[index]['title']), 33 ], 34 )), 35 padding: EdgeInsets.all(2.0), 36 ); 37 }, 38 ); 39 }), 40

投稿2020/03/20 04:48

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問