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

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

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

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

Dart

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

Q&A

解決済

2回答

424閲覧

Flutter Iconsクラスからindexで取得

solachalon

総合スコア7

Flutter

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

Dart

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

0グッド

0クリップ

投稿2022/09/03 13:18

前提

初心者です。

Flutterを使用し、スマホアプリの作成を行っております。
Iconsのクラスを使用し、マテリアルデザインのアイコンを使用できますが、このアイコン全種類を表示し閲覧できるようにしたいです。

実現したいこと

Flutterで使用できるIconsのクラスをFor文などでまわし、引数にindexを設定して、indexに応じてアイコンを返すような関数を作成したいです。

何卒、よろしくお願いいたします

補足情報(FW/ツールのバージョンなど)

Flutter ver:3.0.5
IDE:VSCode
実機でデバッグを行っております。

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

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

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

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

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

guest

回答2

0

ベストアンサー

IconsはIconDataを呼び出してオブジェクトを作っているので、Iconsのソースから、IconDataに渡すコード部分だけを取り出し配列化し、それを元に関数を作る。

変換関数

dart

1final code = <int>[0xe000]; 2IconData indexIcon(int index) { 3 return IconData(code[index], fontFamily: 'MaterialIcons'); 4}

codeの16進部分の作り方。
Iconsの中は以下の様に、識別名とそれに対してIconData生成の実装が入っているので、IconDataの第1引数の16進部分だけをすべて抽出(エディタを使ったりプログラムを使ったり)して配列に納める。

dart

1 /// <i class="material-icons md-36">10k</i> &#x2014; material icon named "10k". 2 static const IconData ten_k = IconData(0xe000, fontFamily: 'MaterialIcons'); 3 4 /// <i class="material-icons-sharp md-36">10k</i> &#x2014; material icon named "10k" (sharp). 5 static const IconData ten_k_sharp = IconData(0xe700, fontFamily: 'MaterialIcons'); 6 7 /// <i class="material-icons-round md-36">10k</i> &#x2014; material icon named "10k" (round). 8 static const IconData ten_k_rounded = IconData(0xf4df, fontFamily: 'MaterialIcons');

IconDataの第1引数に0から0xFFFFまで直接与えてしまうというやり方もあるとは思う。

投稿2022/09/04 02:51

ta.fu

総合スコア1667

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

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

0

回答ありがとうございます。
IconDataは盲点でした。

投稿2022/09/04 03:01

solachalon

総合スコア7

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問