data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
最近、お仕事でFlutterを使ってアプリ開発しています
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
data:image/s3,"s3://crabby-images/a9237/a9237ffe2ed56cc46af4cde1eedaddd793c030d7" alt="魔理沙【悲しみ】"
UnityよりもFlutterのほうが需要あるしな(汗
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
もくじ
解説動画もあるよ!
data:image/s3,"s3://crabby-images/7d4a0/7d4a08031b91e46e7de1d5ad42b9337c4f7b859d" alt="クロ【喜び】"
こちらを見ていただけると嬉しいです!
data:image/s3,"s3://crabby-images/38916/38916c8f03ef4fc1bba2f44c0e0f6e7e19fb8277" alt="霊夢【悲しみ】"
内容自体はあまり進んでないわね
data:image/s3,"s3://crabby-images/3e508/3e50814a956db64692bf62619ca854e5fc3f118a" alt="魔理沙【楽しい】"
このアプリ制作は前座のつもりだったから1回で終えるはずだったんだけどね
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
どうしても時間がかかってしまったというわけですね
Githubにプロジェクトをアップロードしてます!
Githubのプロジェクトリンク:https://github.com/Syungetu/text_editor
data:image/s3,"s3://crabby-images/7d4a0/7d4a08031b91e46e7de1d5ad42b9337c4f7b859d" alt="クロ【喜び】"
ソースを見せろ!といった方はGithubにプロジェクトファイルを上げてますのでご確認ください~
data:image/s3,"s3://crabby-images/38916/38916c8f03ef4fc1bba2f44c0e0f6e7e19fb8277" alt="霊夢【悲しみ】"
data:image/s3,"s3://crabby-images/dd6bb/dd6bb17e17d752babd408427285bdf644234ea79" alt="魔理沙【喜び】"
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
動画について補足的解説をします
data:image/s3,"s3://crabby-images/8b8a6/8b8a6b65baa756b7ee0c3302e37f8f120eac752e" alt="クロ【悲しみ】"
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
とはいえ深いところまでは解説は出来ないから勘弁してね
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
StatelessWidgetとStatefulWidgetの違い
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
もうちょっと解説させてください
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
動画内では静的か動的かの違いって説明したわね
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
ユーザーが操作するとかそういうのも動的って言ったりするしね
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
本来変化しないような要素が変化するときは「動的」になるといった感じかしらね
動的処理の例
String inputText = “入力なし”;
Widget build(BuildContext context) {
return Scaffold(
body: Column(
children: <Widget>[
// 入力されたテキスト
Text(inputText),
// テキスト入力
onChanged: (String value) {
// 入力されたテキストを反映する
inputText = value;
}
),
// テキスト表示を更新する
TextButton(
onPressed: () {
// 画面を更新する
setState((){});
},
child: Text(“入力確定”),
),
],
),
);
}
data:image/s3,"s3://crabby-images/3e508/3e50814a956db64692bf62619ca854e5fc3f118a" alt="魔理沙【楽しい】"
とりあえず、上のようなソースコードがあったとするぞ
// テキスト入力
onChanged: (String value) {
// 入力されたテキストを反映する
inputText = value;
}
),
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
Text(inputText ),
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
TextButton(
onPressed: () {
// 画面を更新する
setState((){});
},
child: Text(入力確定),
),
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
ボタンを押したら「setState」を呼ぶようにしてるぞ
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
とりあえず「Container」で囲っておけ!
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
// Widget外の余白
margin: EdgeInsets.only(
top: 0,
bottom: 0,
left: 5,
right: 5,
),
// Widget内の余白
padding: EdgeInsets.only(
top: 5,
bottom: 5,
left: 0,
right: 0,
),
child: Text(“位置調整テキスト”),
),
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
余白や幅や高さを指定しているわね
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
Imageでの画像表示方法
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
表示したいときとかよくあるわよね
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
Image.asset(‘images/UI/hogehoge.png’), // ネットワークから画像を読み込む
Image.network(‘https://hogehoge.com/sample.jpg’),
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
ただ、ローカルで表示するときにはpubspec.yamlの編集が必要です
pubspec.yamlの編集
assets:
– images/
– images/UserIcon/
– images/UI/
# – images/a_dot_burr.jpeg
# – images/a_dot_ham.jpeg
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
コンパイル時にココを見てアプリに内包するみたいです
次回はリスト表示や読み込み待ちの処理とかを開設予定です
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
今回は動画で解説したことが多くて少なくなってしまったわね
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
“Flutterプログラム解説 簡単なメモアプリを作成してみたよ! その1 UI作成編” への1件の返信