data:image/s3,"s3://crabby-images/7d4a0/7d4a08031b91e46e7de1d5ad42b9337c4f7b859d" alt="クロ【喜び】"
今回もFlutterのプログラム解説をしていこうと思います!
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/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/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="霊夢【普通】"
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
https://github.com/Syungetu/text_editor/blob/main/lib/page/memo_page.dart
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
データを端末に保存する
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
インポートはごく普通な感じですね
SharedPreferences prefs = await SharedPreferences.getInstance();
// titleという項目に文字列データを保存する
prefs.setString(‘title’, titleTextEditingController.text);
// contentsという項目に文字列データを保存する
prefs.setString(‘contents’, contentsTextEditingController.text);
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
今回はテキストデータを保存するものになるわね
// インスタンス取得
SharedPreferences prefs = await SharedPreferences.getInstance();
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
データをやり取りするときは必ずSharedPreferences.getInstance();を呼び出す必要があるぞ
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
// titleという項目に文字列データを保存する
prefs.setString(‘title’, titleTextEditingController.text);
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
保存する「setString()」関数の第一引数は項目名を指定するわ
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
今回は文字列を入力しています
prefs.setInt(‘hogehoge’, title1); → int型で保存
prefs.setDouble(‘hogehoge’, title1.0001); → double型で保存
prefs.setBool(‘hogehoge’, title true); → bool型で保存
prefs.setString(‘hogehoge’, title “hagehage”); → String型で保存
prefs.getStringList(‘hogehoge’, title [“aaa”, “bbb”, “ccc”]); → String型のリストで保存
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
第二引数に入れるデータは関数ごとに分かれてます
data:image/s3,"s3://crabby-images/f88c4/f88c438fd8f59a38e2a1203ddd9c678daaed9931" alt="霊夢【普通】"
保存したデータの読み込み
// インスタンス取得
SharedPreferences prefs = await SharedPreferences.getInstance();
// titleという項目に保存した文字列データを読み込む
String? titleText = prefs.getString(‘title’);
if (titleText != null) {
titleTextEditingController.text = titleText;
}
// contentsという項目に保存した文字列データを読み込む
String? contentsText = prefs.getString(‘contents’);
if (contentsText != null) {
contentsTextEditingController.text = contentsText;
}
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
こちらも同じ様な処理で出来るからわかりやすいな
// インスタンス取得
SharedPreferences prefs = await SharedPreferences.getInstance();
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
保存時と同じようにインスタンスが生成されるまで待ちます
// titleという項目に保存した文字列データを読み込む
String? titleText = prefs.getString(‘title’);
if (titleText != null) {
titleTextEditingController.text = titleText;
}
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="魔理沙【普通】"
保存されてないものを呼び出そうとするとnullが返されるぞ
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="霊夢【普通】"
まずはドラムロールが出来るFlutter Datetime Pickerを追加するわ
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"
ドラムロールを追加する
import ‘package:flutter_datetime_picker/flutter_datetime_picker.dart’;
import ‘package:timezone/data/latest.dart’ as tz;
import ‘package:timezone/timezone.dart’ as tz;
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
先程追加した2つのパッケージを追加した感じですね
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="妖夢【普通】"
そのため別名で飛び出すことでエラーを回避する事ができます
// 通知日付設定を行う
await DatePicker.showDateTimePicker(
context,
showTitleActions: true,
locale: LocaleType.jp,
currentTime: DateTime.now(),
// ピッカーを動かしたときに呼ばれる
onChanged: (time) {},
// 日付設定が完了したときに呼ばれる
onConfirm: (time) {
setSheetState(() {
selectDateTime = time;
});
},
);
data:image/s3,"s3://crabby-images/0783d/0783d6774948990a33c17f34f8ce27bbed4f1e7a" alt="クロ【普通】"
「 DatePicker.showDateTimePicker()」がドラムロールを呼び出す処理となります
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="霊夢【普通】"
data:image/s3,"s3://crabby-images/aa541/aa54179c543baa9562408a814ae6594499873fa1" alt="魔理沙【普通】"
data:image/s3,"s3://crabby-images/0c8f5/0c8f5bf287b703f1001a4e888bfc8d1ca1e02546" alt="妖夢【普通】"