Compare commits

...

219 Commits

Author SHA1 Message Date
301d097cd6 Merge pull request '本番環境移行' (#60) from 本番環境以降 into master
Reviewed-on: #60
2024-07-24 06:34:15 +00:00
nemukemo
7bfda687cd 粉砕玉砕大喝采 2024-07-24 15:32:54 +09:00
nemukemo
c61e41a8ae setupが落ちる原因を取り除く
FirestoreReceptionを本番用にしてい
uuidもreturn値を固定解除
2024-07-24 15:29:17 +09:00
422e105808 Merge pull request 'アイコンや設定画面を切り離しなど' (#59) from murakumo_Home画面をぶっ壊す into master コンフリ起きない万歳
Reviewed-on: #59
2024-07-19 01:45:37 +00:00
nemukemo
856e125612 webpども:アプリアイコンのため
SettingView:設定画面作成
main:設定情報を切り離した
その他:intentの調整
2024-07-19 10:44:32 +09:00
2c0bb36c68 Merge pull request '背景色消して○で表現できるようにした。すごい' (#58) from murakumo_Mapに○を into master
Reviewed-on: #58
2024-07-17 05:30:25 +00:00
b2f452c6fe Merge pull request '提出状況-1問題の解決' (#57) from murakumo_提出状況-1問題 into master
Reviewed-on: #57
2024-07-17 05:28:44 +00:00
nemukemo
1c1f366bf8 背景色消して○で表現できるようにした 2024-07-17 14:27:08 +09:00
nemukemo
bb4912f123 uuid:値をテストデータに固定中
main:各メソッドが何の処理をしているかのコメント追加
SubmissionActivity:nullチェックと謎のコード削除
SubmissionAdapter:色のセットなどをメソッド化
submission.xml:recyclerviewがマッチョペアレントだったから-1されるフレンズでした。てへぺろ
2024-07-17 12:23:41 +09:00
f28fd3c4ff Merge pull request 'murakumo_URLコピペボタンの作成完了' (#56) from murakumo_URLコピペボタン into master oh year
Reviewed-on: #56
2024-07-16 05:32:54 +00:00
nemukemo
d3c94b5a7b コンクリ解消 2024-07-16 14:31:50 +09:00
nemukemo
98f35c6555 Merge branch 'master' into murakumo_URLコピペボタン
# Conflicts:
#	app/src/main/java/com/example/oplogy/MainActivity.java
2024-07-16 14:30:59 +09:00
nemukemo
6f968f2b9b 再コミット 2024-07-16 14:26:37 +09:00
9c523c1047 Merge pull request 'NowLoading作成完了' (#54) from murakumo_NowLoading into master
Reviewed-on: #54
2024-07-16 05:20:05 +00:00
nemukemo
52a03156a2 NowLoading作成完了 2024-07-16 14:15:35 +09:00
nemukemo
e7a7838c2b コピペボタンの作成
レイアウトを調整する必要あり
2024-07-16 00:31:15 +09:00
65edd2e9f8 Merge pull request 'マップ表示のバグ修正' (#53) from murakumo_classIdが0になる問題 into master
Reviewed-on: #53
2024-07-15 04:17:56 +00:00
nemukemo
4e20d0006f マップ表示のバグ修正 2024-07-14 01:12:56 +09:00
2f2c99cf6f Merge pull request 'classIdの表示する時、0になる問題を解決' (#51) from murakumo_classIdが0になる問題 into master
Reviewed-on: #51
2024-07-12 01:16:34 +00:00
nemukemo
ecbb551c35 classIdの表示する時、0になる問題を解決 2024-07-12 10:15:21 +09:00
8f606dd30d Merge pull request '・重複時のダイアログに保護者の情報が表示されるように調整しました。' (#50) from api into master
Reviewed-on: #50
2024-07-10 07:31:26 +00:00
fe7752e758 Merge branch 'master' into api
# Conflicts:
#	app/src/main/java/com/example/oplogy/MainActivity.java
2024-07-10 16:21:05 +09:00
6a5eca8000 ・重複時のダイアログに保護者の情報が表示されるように調整しました。
・その他細かなバグを修正しました。
2024-07-10 16:13:24 +09:00
362b7b5544 プルリクエスト 'ID作成時に表示をダイアログに変更、セットアップが終了していない場合にtoast表示を行い遷移しないように変更' (#49) from last into master
Reviewed-on: #49
2024-07-10 07:09:15 +00:00
nemukemo
356021beae ID,セットアップが終わっていない場合にtoast表示を行う 2024-07-10 16:07:02 +09:00
nemukemo
d96f67b09b Merge remote-tracking branch 'origin/master'
# Conflicts:
#	app/src/main/java/com/example/oplogy/FirestoreReception.java
2024-07-09 19:51:59 +09:00
nemukemo
634547622a あとでろるばすりゅ 2024-07-09 19:49:58 +09:00
2245d5a5b3 Merge pull request 'api' (#48) from api into master
Reviewed-on: #48
2024-07-09 10:45:07 +00:00
02212be21e Merge remote-tracking branch 'origin/api' into api 2024-07-09 19:44:46 +09:00
0534bc75d4 小林最終提出 2024-07-09 19:44:12 +09:00
823fa8a2c4 Merge pull request 'api' (#47) from api into master
Reviewed-on: #47
2024-07-09 03:10:45 +00:00
470abcd53e 全ての変数名に型名がわかるように追記 2024-07-09 12:10:14 +09:00
0652ce505b ルート表示の成功
maps.javaへのコメントとコードの可読性向上
2024-07-09 11:32:19 +09:00
46a00a3337 Merge pull request '以下の機能を追加' (#46) from finishing into master
Reviewed-on: #46
2024-07-08 22:47:56 +00:00
c8af823a46 以下の機能を追加
・CreateScheduleの再作成
・CreateScheduleによって生成されたスケジュールの順番に並んだ実際の緯度経度、保護者情報のmapへのピン刺し&スクロールビューへの表示
・スクロールビューの要素数が増えるにつれて無尽蔵に画面を覆いつくしmapが見えなくなる不具合の修正
・スクロールビューをタッチすると対応したピンにカメラがフォーカスされる機能の追加
・スケジュールの順番に合わせてピン間のルートを表示する機能の追加(APIの問題により未完成)
・Maps.javaにおいてピンの色とスクロールビューの色が対応していないかつ5種類以上の色が使えない問題の修正(GooglemapApiのピンでは特定の10色しか使えないらしい)
2024-07-09 07:47:25 +09:00
bf24921cd7 Merge pull request '菊池' (#38) from AlsoMaps into master
Reviewed-on: #38
2024-07-08 07:58:12 +00:00
54da345315 Merge branch 'master' into AlsoMaps
# Conflicts:
#	app/src/main/java/com/example/oplogy/CreateRoot.java
2024-07-08 16:57:53 +09:00
bc3c802e03 菊池
複数の日を入れれるように書き直しました。
大きさは今後直せますが、取り敢えず今い作ったコードでちゃんと動くのか試してください。
大きさは変わり次第報告します
2024-07-08 15:32:50 +09:00
5599ff7b1d 菊池
取り敢えず3日分でテストしてみました。
別々の値で入れていますので、問題ないかと思います。
2024-07-08 13:06:53 +09:00
f3a3733e16 Merge pull request '作業kan' (#44) from murakumo_dao追加 into master
Reviewed-on: #44
2024-07-08 03:41:38 +00:00
nemukemo
69cbdf41f0 作業kan 2024-07-08 12:41:04 +09:00
819e15de6f Merge pull request '・セットアップに設定した初期地点の緯度経度化' (#42) from finishing into master
Reviewed-on: #42
2024-07-08 03:14:48 +00:00
ba9a53af02 ・セットアップに設定した初期地点の緯度経度化 2024-07-08 12:13:43 +09:00
20a5100a6a 菊池
新しいレイアウトを作りました。
2024-07-08 11:45:58 +09:00
1730c9b601 Merge pull request '・コード整形' (#41) from finishing into master
Reviewed-on: #41
2024-07-08 01:23:52 +00:00
ef4cf1c934 Merge branch 'master' into finishing
# Conflicts:
#	app/src/main/java/com/example/oplogy/SetUpActivity.java
2024-07-08 10:23:14 +09:00
626bc98764 ・コード整形
・セットアップに設定した初期地点の緯度経度化(未達)
2024-07-08 10:21:43 +09:00
6bd05b1008 Merge pull request 'datePicker' (#40) from datePicker into master
Reviewed-on: #40
2024-07-08 01:21:12 +00:00
216cde59a3 Merge pull request 'ID作成、セットアップの処理をしなかった場合にルート表示を押したときに入力を促すダイアログの表示' (#39) from murakumo_ルート作成する前の警告 into master
Reviewed-on: #39
2024-07-08 01:20:58 +00:00
nemukemo
02b96cb10f ID作成、セットアップの処理をしなかった場合にルート表示を押したときに入力を促すダイアログの表示 2024-07-08 09:21:00 +09:00
1b6e22f677 菊池
ピンと色が一致するようになり、ピンをクリックと名前などが見えるように設定しました。
Main画面でUUID作成を押したときに、(Yes/No)を押してもチェックが消えなかったのでそこの訂正もしました。
そこの変更も確認お願いします。
2024-07-07 22:08:44 +09:00
Ekamo-11
6f9f4bce75 必須項目が記入されていないを画面に表示する条件を変更しました。 2024-07-05 13:11:12 +09:00
Ekamo-11
4808e7a761 必須項目が記入されていなかったら。Toastでその状態を知らせるプログラムを作成しました。 2024-07-05 12:50:53 +09:00
a17c2c633f Merge pull request '現在の最新' (#37) from finishing into master
Reviewed-on: #37
2024-07-05 03:28:37 +00:00
3300713e54 現在の最新 2024-07-05 12:28:18 +09:00
Ekamo-11
01c3a27930 機能を説明するコメントを追加しました。 2024-07-05 12:06:06 +09:00
77baea99c5 Merge pull request 'docking' (#36) from docking into master
Reviewed-on: #36
2024-07-05 03:04:50 +00:00
be1b09b4a0 コンフリクト解消 2024-07-05 12:04:19 +09:00
06fdb9a312 Merge branch 'master' into docking
# Conflicts:
#	app/src/main/java/com/example/oplogy/MainActivity.java
2024-07-05 12:00:08 +09:00
de77c75b0b CreateScheduleによって緯度経度に変換した住所を元にルート作成の成功 2024-07-05 11:56:47 +09:00
Ekamo-11
2bb1587668 変数名を型が分かるようにさらにさらにさらに一部変更しました。 2024-07-05 11:56:09 +09:00
Ekamo-11
55f5033fc6 変数名を型が分かるようにさらにさらに一部変更しました 2024-07-05 11:53:29 +09:00
Ekamo-11
34bbf40951 変数名を型が分かるようにさらに一部変更しました 2024-07-05 11:50:08 +09:00
Ekamo-11
1b0356f4c2 Merge branch 'master' into datePicker 2024-07-05 11:45:57 +09:00
Ekamo-11
3109d9666d 変数名を型が分かるように一部変更しました 2024-07-05 11:45:23 +09:00
640251b9f5 Merge pull request 'ID作成の処理を作成、更新に切り替えて、それに合わせて処理を変更' (#35) from murakumo_IDの処理変更 into master
Reviewed-on: #35
2024-07-05 02:39:35 +00:00
nemukemo
4bf097c04d ID作成の処理を作成、更新に切り替えて、それに合わせて処理を変更 2024-07-05 11:30:52 +09:00
1dac132799 CreateRootをCreatescheduleに変更 2024-07-05 10:26:54 +09:00
8a23bd3f8a Merge pull request 'ルート作成時のダイアログ関連の修正' (#34) from murakumo_ダイアログ祭り into master
Reviewed-on: #34
2024-07-05 00:52:13 +00:00
nemukemo
914e49bccb ルート作成時のダイアログ関連の修正 2024-07-04 18:40:52 +09:00
Ekamo-11
036352858f 警告を消すためにリソースを追加しました、その他の警告も消しました。 2024-07-03 16:46:22 +09:00
Ekamo-11
0e40dea54c setUpActivityの担任の名前と開始地点を日本語キーボードで入力するようにしました。多分端末ごとの設定な気がするけど 2024-07-03 16:35:33 +09:00
a9107ee8ea Merge pull request '変数名とコメントの調整(済)' (#33) from test into master
Reviewed-on: #33
2024-07-03 07:18:16 +00:00
Ekamo-11
500f24f4f5 StringのリソースファイルにDatePickerの表示形式を日本語にするためのリソースを追加しました。 2024-07-03 16:18:04 +09:00
0f8ee6283a 変数名とコメントの調整(済) 2024-07-03 16:17:43 +09:00
a1a6b78e4a Merge pull request 'hotfix/restore_missing' (#32) from hotfix/restore_missing into master
Reviewed-on: #32
2024-07-03 07:07:47 +00:00
845557220d
型をStringからIntegerに変更 2024-07-03 16:06:16 +09:00
97ce89789b
maps.xmlへの変更をRevert 2024-07-03 15:47:47 +09:00
619b22dc02
Maps.javaへの変更をRevert 2024-07-03 15:46:11 +09:00
cd37533afd
all_ok.png復元 2024-07-03 15:45:56 +09:00
8b72a68026
InsertClassIdforFirebase復元 2024-07-03 15:44:46 +09:00
9536b0d9c2 Merge pull request '変数名とコメントの調整(未完)' (#31) from CreateRoot2 into master
Reviewed-on: #31
2024-07-03 06:12:53 +00:00
1d8115a448 Merge branch 'master' into CreateRoot2
# Conflicts:
#	app/src/main/java/com/example/oplogy/CreateRoot.java
2024-07-03 15:12:23 +09:00
9d20a07164 変数名とコメントの調整(未完) 2024-07-03 15:11:33 +09:00
09d0c2d259 Merge pull request 'datePicker' (#30) from datePicker into master
Reviewed-on: #30
2024-07-03 05:23:34 +00:00
Ekamo-11
98572a1bb1 DatePickを使用して、SetUpに入れる機能が完成しました。SharedPreferencesにも保存しました。
追記:バグとり完了part2
2024-07-03 14:21:56 +09:00
Ekamo-11
ca1dca59cc Merge branch 'master' into datePicker
# Conflicts:
#	.idea/gradle.xml
#	app/src/main/java/com/example/oplogy/CreateRoot.java
#	app/src/main/java/com/example/oplogy/MainActivity.java
2024-07-03 14:18:29 +09:00
Ekamo-11
6380263dfc DatePickを使用して、SetUpに入れる機能が完成しました。SharedPreferencesにも保存しました。
追記:バグとり完了
2024-07-03 13:59:22 +09:00
0419ba85bc Merge pull request 'myDataListのAddress(住所)をlatlng(緯度経度)に変換する処理の実装' (#27) from CreateRoot2 into master
Reviewed-on: #27
2024-07-03 04:53:18 +00:00
6a424b234b myDataListのAddress(住所)をlatlng(緯度経度)に変換する処理の実装 2024-07-03 13:49:10 +09:00
Ekamo-11
1e30cfed78 DatePickを使用して、SetUpに入れる機能が完成しました。SharedPreferencesにも保存しました。 2024-07-02 16:45:28 +09:00
26516e48cf Merge pull request 'myDataListのAddress(住所)をlatlng(緯度経度)に変換する処理の実装' (#25) from CreateRoot2 into master
Reviewed-on: #25
2024-07-02 05:07:16 +00:00
05f916afba Merge pull request 'CreateLot' (#24) from CreateLot into master
Reviewed-on: #24
2024-07-02 05:06:38 +00:00
85f736c913 Merge pull request 'murakumo_idが被らない用ロジック実装版' (#23) from murakumo_idが被らない用ロジック実装版 into master
Reviewed-on: #23
2024-07-02 05:05:17 +00:00
Ekamo-11
7deaaa7731 DatePickクラスを生成しました 2024-07-02 13:54:40 +09:00
1f1f96bf56 菊池
確認お願いします
2024-07-02 13:53:43 +09:00
Ekamo-11
b730f5378d DatePicker用の変数を追加しました。 2024-07-02 13:52:57 +09:00
nemukemo
8d4c4a0c4c classIdのロジックとclassIdの呼び出しを両方同じブランチに書いちゃった☆コンフリったら分けてね 2024-07-01 19:18:01 +09:00
Ekamo-11
a08b9c33ae 仕様に修正があったので、レイアウトを修正し、変数も変更しました。 2024-06-28 16:20:56 +09:00
54f1b20393 myDataListのAddress(住所)をlatlng(緯度経度)に変換する処理の実装 2024-06-28 12:40:55 +09:00
nemukemo
0c569b0a57 デバッグなう 2024-06-28 12:40:00 +09:00
97fb84e3a6 菊池
Mapsの中をWebViewに変えて、経路案内処理に変えました。
確認お願いします
2024-06-28 12:27:57 +09:00
Ekamo-11
444d1a0469 追加したボタンに対する変数を追加しました 2024-06-28 11:51:49 +09:00
Ekamo-11
da8dd8ff16 layoutを3日分開始時刻と終了時刻を設定できるように変更しました。それに伴ってボタンのIDも変更しました。 2024-06-28 11:41:33 +09:00
b29545dc0d Merge pull request 'murakumo_UUIDを何とかするの会_roomに追加し隊' (#22) from murakumo_UUIDを何とかするの会_roomに追加し隊 into master
Reviewed-on: #22
2024-06-28 02:15:45 +00:00
nemukemo
55a41ce13c 修正なう 2024-06-28 11:15:20 +09:00
0a0fbaa38b Merge pull request 'murakumo_UUIDを何とかするの会' (#21) from murakumo_UUIDを何とかするの会 into master
Reviewed-on: #21
2024-06-28 02:02:01 +00:00
nemukemo
1da1217bda マージ中 2024-06-28 11:01:14 +09:00
nemukemo
28afc982a7 roomにclassIdフィールドの追加、
firestoreがclassIdを基準に受け取るように変更、
FirestoreReceptionを呼び出すタイミングを他のアクティビティから戻ってきたタイミングに変更
2024-06-28 10:38:49 +09:00
a4f88970c3 Merge pull request '重複した出席番号を表示する処理を追加' (#20) from CreateRoot2 into master
Reviewed-on: #20
2024-06-28 01:32:30 +00:00
5a9d1d83be 重複した出席番号を表示する処理を追加 2024-06-28 10:32:05 +09:00
b15dcabd50 Merge pull request 'CreateRoot2' (#19) from CreateRoot2 into master
Reviewed-on: #19
2024-06-28 01:21:56 +00:00
6bd8a4ab81 コンフリクト修正 2024-06-28 10:21:32 +09:00
af694c67f0 マージのためのコミット 2024-06-28 10:16:08 +09:00
56d54192d2 コード整形 2024-06-28 10:08:29 +09:00
d98293a80d スケジュール作成のコード完成
エラーのダイアログだけ修正必須
2024-06-27 20:51:57 +09:00
323b283208 記録 2024-06-27 17:49:55 +09:00
nemukemo
4a873ffd39 roomにclassIdフィールドの追加、
firestoreがclassIdを基準に受け取るように変更、
FirestoreReceptionを呼び出すタイミングを他のアクティビティから戻ってきたタイミングに変更
2024-06-27 12:42:38 +09:00
nemukemo
9b56412cb0 classIdを受け取るロジックが画面遷移から戻ってきたときにも実行されるように変更 2024-06-26 16:30:37 +09:00
nemukemo
1c210f62aa UUIDの作成完了したけど、
1.roomにString classIdの作成
2.SetUpの際に、classIdを挿入すること
3.classIdをmainアクティビティで取得する手段を作る
4.以上のことを実装するためにユーザーにid作成、setupをすることを促すような制限をかける
2024-06-25 20:09:21 +09:00
9bad03da2d Merge pull request 'murakumo_修正パッチその2' (#18) from murakumo_修正パッチその2 into master
Reviewed-on: #18
2024-06-24 09:50:24 +00:00
nemukemo
f658c3c32e submissionの完成 2024-06-24 18:48:30 +09:00
nemukemo
bafc7df037 一旦コメント退避part2 2024-06-24 18:42:13 +09:00
nemukemo
720f4cd16e 一旦コメント退避 2024-06-24 18:17:42 +09:00
2e61c4c3f7 Merge pull request 'メソッド化' (#17) from murakumo_修正パッチその1 into master
Reviewed-on: #17
2024-06-24 08:53:31 +00:00
nemukemo
a95c9abbbb メソッド化 2024-06-24 17:52:54 +09:00
e5407e0cdb Merge pull request '最低限の修正' (#16) from murakumo_submission_ver2 into master
Reviewed-on: #16
2024-06-24 06:06:06 +00:00
nemukemo
8281474e02 最低限の修正 2024-06-24 15:05:30 +09:00
55302e9665 Merge pull request 'バグ修正' (#14) from murakumo_uuidのダイアログのバグ修正 into master
Reviewed-on: #14
2024-06-24 02:11:55 +00:00
nemukemo
f66a9bb8bd バグ修正
⇒finish()を削除しました
2024-06-24 10:36:18 +09:00
e4a4d66237 Merge pull request 'muakumo_バグ修正' (#13) from muakumo_バグ修正 into master
Reviewed-on: #13
2024-06-21 02:03:39 +00:00
nemukemo
f9a73bc046 Dao修正 2024-06-21 11:02:41 +09:00
nemukemo
03ec5e0717 Dao修正 2024-06-21 11:01:21 +09:00
664dffb389 Merge pull request 'intervalArrayから家庭訪問の休憩時間を除去する処理の追加' (#12) from CreateRoot2 into master
Reviewed-on: #12
2024-06-21 01:54:53 +00:00
29ce87d6a1 intervalArrayから家庭訪問の休憩時間を除去する処理の追加 2024-06-21 10:54:27 +09:00
412add9c61 Merge pull request 'CreateMapsetc' (#11) from CreateMapsetc into master
Reviewed-on: #11
2024-06-21 01:53:19 +00:00
fc25e35a77 Merge pull request 'ルート作成画面の遷移時にformに送られた人数が足りてない場合、警告のダイアログを出すように変更' (#9) from murakumo_setupの情報をroomに保存し隊 into master
Reviewed-on: #9
2024-06-21 01:53:00 +00:00
nemukemo
13120b9856 バグ修正 2024-06-21 10:51:26 +09:00
1a7085e99c 菊池
マップに複数のピンを入れる処理を書きました。
画像を押しても遷移できるようにしました。
レイアウトの確認をお願いします
2024-06-21 10:28:26 +09:00
b94419d157 Merge pull request 'CreateRoot2' (#10) from CreateRoot2 into master
Reviewed-on: #10
2024-06-20 10:57:02 +00:00
d6c834e4ca roomからintervalTime,startBreakTime,endBreakTimeを取得する処理を追加。 2024-06-20 19:56:41 +09:00
4dfc928571 Roomに関する不具合を修正 2024-06-20 19:51:17 +09:00
nemukemo
410d4f2402 削除機能の実装 2024-06-20 18:27:17 +09:00
d7ad6dce7c Merge pull request 'room値を拾う処理を実装' (#8) from CreateRoot2 into master
Reviewed-on: #8
2024-06-20 09:22:25 +00:00
6fc1e6daa5 room値を拾う処理を実装 2024-06-20 18:21:47 +09:00
nemukemo
b99aa2973d ルート作成画面の遷移時にformに送られた人数が足りてない場合、警告のダイアログを出すように変更 2024-06-20 13:06:20 +09:00
a3dd2f922d Merge pull request 'CreateRoot2' (#7) from CreateRoot2 into master
Reviewed-on: #7
2024-06-19 09:39:26 +00:00
b3f6d3a9ab timezoneの長さが短い順にmyDataListの要素を並び替える処理と
timestampを日付に変換する処理を実装
2024-06-19 18:38:40 +09:00
8c6cbc5387 菊池
マップに複数のピンを入れる処理を書きました
2024-06-19 16:59:59 +09:00
a3aa4a10e4 菊池
マップに複数のピンを入れる処理を書きました
2024-06-19 16:59:45 +09:00
7582d948ef Merge pull request 'SetUpActivityで情報の保存および更新する処理の実装完了' (#6) from murakumo_setupの情報をroomに保存し隊 into master
Reviewed-on: #6
2024-06-19 07:13:51 +00:00
nemukemo
2ad164b721 SetUpActivityで情報の保存および更新する処理の実装完了 2024-06-19 16:10:59 +09:00
22ed9e3a31 firstDayのTimeStampの0番目と1番目から家庭訪問の希望時間帯の長さtimezoneをdataに追加する処理を実装 2024-06-19 15:34:13 +09:00
f7d955c4a6 菊池
ボタンのインテント調整
バグの修正を入れました。確認をお願いします
2024-06-19 15:16:32 +09:00
eec3846eb4 Merge pull request 'SpreadSheet' (#3) from SpreadSheet into master
Reviewed-on: #3
2024-06-19 05:51:27 +00:00
52417809d6 Merge branch 'master' into SpreadSheet 2024-06-19 14:50:52 +09:00
a865ade4d6 Merge branch 'master' into SpreadSheet 2024-06-19 14:50:23 +09:00
c5d6e9ebc5 Merge pull request 'GeoCoder.classへの遷移を後に変更' (#5) from CreateRoot2 into master
Reviewed-on: #5
2024-06-19 05:49:49 +00:00
ab41832ebd Merge branch 'master' into CreateRoot2
# Conflicts:
#	app/src/main/java/com/example/oplogy/MyDataClass.java
2024-06-19 14:49:19 +09:00
a236c7c05b Merge pull request 'roomをformの受信からSetUpの保存に置き換え' (#4) from murakumo_roomの機能をセットアップテーブルにし隊 into master
Reviewed-on: #4
2024-06-19 05:42:13 +00:00
79042493f6 GeoCoder.classへの遷移を後に変更
FirestoreReception.javaから直接 CreateRoot.javaにmyDataListを渡すコードに
2024-06-19 14:40:51 +09:00
nemukemo
74062283af roomをformの受信からSetUpの保存に置き換え 2024-06-19 14:37:53 +09:00
Ekamo-11
135caebda3 main画面に戻る機能と、レイアウトファイルのidを変更しました 2024-06-19 14:15:05 +09:00
Ekamo-11
029eacc629 リセットボタンについてメモを追加しました 2024-06-19 14:02:06 +09:00
507cfc739c Merge pull request 'CreateRoot' (#2) from CreateRoot into master
Reviewed-on: #2
2024-06-19 04:55:22 +00:00
8ab335a9eb 全体マージのため 2024-06-19 13:51:04 +09:00
e9d4764ba0 Merge pull request 'firestoreから送られてくるデータのmap化' (#1) from murakumo-v2 into master
Reviewed-on: #1
2024-06-19 04:48:47 +00:00
nemukemo
f0024f64d3 firestoreから受け取ったデータを一本の配列(Map)化 2024-06-18 20:45:52 +09:00
nemukemo
8e8916c47b Revert "revert 25bc379d25822b3dfd8c6907ae017ed2296dc8cd"
This reverts commit 4ba6437357.
2024-06-18 19:24:58 +09:00
4ba6437357 revert 25bc379d25
revert firestoreから受け取ったデータを一つの配列化
2024-06-18 10:21:49 +00:00
nemukemo
25bc379d25 firestoreから受け取ったデータを一つの配列化 2024-06-18 19:12:37 +09:00
38a565c392 giteaへの変更のためのコミット 2024-06-18 17:20:34 +09:00
Ekamo-11
e7d26cff81 リセットボタンを押すとテキストとラジオボタンの選択が消えるように設定しました。 2024-06-18 16:13:23 +09:00
70408eb7b0 MainActivityでMaps_Activityに遷移してた部分をMapsActivityに変更 2024-06-18 16:02:01 +09:00
Ekamo-11
3e3d750b85 ファイルの名前の変更とリセットボタンの変数を作成しました 2024-06-18 16:01:46 +09:00
ユタ氏
dab6d60ee9
Merge pull request #19 from N-YOKU-jp/CreateEtc
菊池
2024-06-18 15:54:04 +09:00
5c7b4a28d7 菊池
マップとスクロールを表示できました。確認をお願いします
2024-06-18 15:28:02 +09:00
0b4493378d バグ修正その2 2024-06-18 15:14:32 +09:00
e281c6e827 バグ修正 2024-06-18 15:11:34 +09:00
2c32a1b6d5 Merge remote-tracking branch 'origin/master'
# Conflicts:
#	app/src/main/java/com/example/oplogy/SetupActivity.java
2024-06-18 14:57:09 +09:00
19a2385265 2024/06/18 14:49時点最新master 2024-06-18 14:56:41 +09:00
ユタ氏
1e954780cc
Merge pull request #18 from N-YOKU-jp/room_murakumo_セッティング
roomいったん完了
2024-06-18 14:43:09 +09:00
nemukemo
f41238b22f roomいったん完了 2024-06-18 14:42:15 +09:00
794d3b1cfb Gradleにroomの依存関係を追加 2024-06-18 14:32:18 +09:00
a599489e9c Merge remote-tracking branch 'origin/master'
# Conflicts:
#	app/src/main/res/layout/setup.xml
2024-06-18 14:02:16 +09:00
8968a96ead 井伊君の実装を結合 2024-06-18 14:01:42 +09:00
ユタ氏
79818ca141
Merge pull request #14 from N-YOKU-jp/CreateUi
Create UI
2024-06-14 12:50:46 +09:00
ユタ氏
312dbac710
Merge branch 'master' into CreateUi 2024-06-14 12:50:38 +09:00
ユタ氏
80a5be5c2e
Merge pull request #13 from N-YOKU-jp/CreateRoot
緯度経度の処理をGeoCodingではなくGeoCoderで実装。緯度経度変換成功
2024-06-14 12:33:01 +09:00
8c634499ae 緯度経度の処理をGeoCodingではなくGeoCoderで実装。緯度経度変換成功 2024-06-14 12:29:30 +09:00
e5f35c6ca4 ・Firebaseから受け取った住所の緯度経度変換(未達)(エラーはでない) 2024-06-14 11:12:43 +09:00
e26c482dc2 菊池
マップとスクロールを表示できました。確認をお願いします
2024-06-14 10:16:46 +09:00
0f74ea09cf 菊池
マップを表示するところまで行きました。
ScrollViewが見えなくなっているので、そこだけ直せば行ける感じです。
取り敢えず動く範囲だけでプッシュします。
2024-06-12 15:27:48 +09:00
64f08d1c6c Merge branch 'master' into CreateUi 2024-06-11 16:00:29 +09:00
a05ee74ae1 菊池
マップ用のエンプティアクティビティとマップフラグメントとして分けて作りました(googleMapの中でスクロールとかを入れれなかったので)
2024-06-11 15:59:36 +09:00
ユタ氏
87e610d4f4
Merge pull request #11 from N-YOKU-jp/reception_murakumo_ver2
クラスIDを元にデータの受信
2024-06-11 15:54:34 +09:00
ユタ氏
b1ab4417e6
Merge pull request #9 from N-YOKU-jp/UUID
ダイアログの作成
2024-06-11 15:53:22 +09:00
7d2ee567f3 ダイアログの作成
uuidの作成
2024-06-11 15:47:22 +09:00
nemukemo
5b8dd48881 クラスIDを元にデータの受信 2024-06-11 15:27:50 +09:00
248666695e マージによるファイルの干渉を原因としたAndroidManifestのエラーを修正 2024-06-11 14:49:54 +09:00
ユタ氏
4639ee8d53
Merge pull request #7 from N-YOKU-jp/Setup
Setup
2024-06-11 14:17:30 +09:00
ユタ氏
5a33390c86
Merge branch 'master' into Setup 2024-06-11 14:17:00 +09:00
Ekamo-11
d4b847db2e jsonファイルを保存しました 2024-06-11 14:14:01 +09:00
ユタ氏
05598940a7
Merge pull request #4 from N-YOKU-jp/CreateUi
Create UI
2024-06-11 14:09:14 +09:00
Ekamo-11
6effabbb9c さらにレイアウトを見やすく改良しました 2024-06-11 14:01:21 +09:00
99de732dbb 菊池
提出状況のインテントを変えました。確認をお願いします。
2024-06-11 13:32:34 +09:00
5bb1a225ba 菊池
インテント繋げました
2024-06-07 13:12:21 +09:00
Ekamo-11
46bbea4d74 さらにレイアウトを見やすく改良しました 2024-06-07 11:36:22 +09:00
Ekamo-11
f19a0004bb レイアウトを少し改良しました、警告もおおよそ消してあります 2024-06-07 11:03:12 +09:00
Ekamo-11
a265e81d2d 仮にレイアウトを作りました 2024-06-07 10:08:14 +09:00
Ekamo-11
405ece3734 仮に必要な要素を入力するフォームを作りました。 2024-06-06 14:23:38 +09:00
Ekamo-11
b423b919ac firebase導入とSetUpActivityを作成しました 2024-06-06 13:58:11 +09:00
5ec3e7929c 菊池
メインのレイアウト作成に取り掛かりました。
インテント等はまだ入れていません。
使用する画像等は、使うところの名前を入れています。
確認をよろしくお願いします。
2024-06-05 22:48:51 +09:00
c42959d736 菊池
チェックボックスのイメージ画像をいれた
2024-06-05 21:31:24 +09:00
1e6c0dc29f 菊池
チェックボックスのイメージ画像をいれた
2024-06-05 21:25:49 +09:00
455e903026 菊池
メインの作成開始と、全体の名前の変更
2024-06-05 16:57:59 +09:00
4e65216874 使用するActivityの事前作成 2024-06-05 16:24:29 +09:00
ac3db6c0e4 統合完了 2024-06-05 15:04:54 +09:00
ユタ氏
b10f3409a6
Merge pull request #3 from N-YOKU-jp/newNemukemo
cloudFireStore追加
2024-06-05 14:25:15 +09:00
65 changed files with 3542 additions and 282 deletions

View File

@ -5,14 +5,15 @@
<option name="linkedExternalProjectsSettings"> <option name="linkedExternalProjectsSettings">
<GradleProjectSettings> <GradleProjectSettings>
<option name="testRunner" value="GRADLE" /> <option name="testRunner" value="GRADLE" />
<option name="distributionType" value="DEFAULT_WRAPPED" />
<option name="externalProjectPath" value="$PROJECT_DIR$" /> <option name="externalProjectPath" value="$PROJECT_DIR$" />
<option name="gradleJvm" value="jbr-17" />
<option name="modules"> <option name="modules">
<set> <set>
<option value="$PROJECT_DIR$" /> <option value="$PROJECT_DIR$" />
<option value="$PROJECT_DIR$/app" /> <option value="$PROJECT_DIR$/app" />
</set> </set>
</option> </option>
<option name="resolveExternalAnnotations" value="false" />
</GradleProjectSettings> </GradleProjectSettings>
</option> </option>
</component> </component>

View File

@ -1,6 +1,6 @@
<project version="4"> <project version="4">
<component name="ExternalStorageConfigurationManager" enabled="true" /> <component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="ProjectRootManager" version="2" languageLevel="JDK_17" project-jdk-name="jbr-17" project-jdk-type="JavaSDK"> <component name="ProjectRootManager" version="2" languageLevel="JDK_17" default="true" project-jdk-name="jbr-17" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/build/classes" /> <output url="file://$PROJECT_DIR$/build/classes" />
</component> </component>
<component name="ProjectType"> <component name="ProjectType">

View File

@ -36,7 +36,7 @@ android {
} }
dependencies { dependencies {
implementation 'com.google.maps:google-maps-services:0.15.0'
implementation 'androidx.appcompat:appcompat:1.6.1' implementation 'androidx.appcompat:appcompat:1.6.1'
implementation 'com.google.android.material:material:1.5.0' implementation 'com.google.android.material:material:1.5.0'
implementation 'androidx.constraintlayout:constraintlayout:2.1.4' implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
@ -45,4 +45,18 @@ dependencies {
testImplementation 'junit:junit:4.13.2' testImplementation 'junit:junit:4.13.2'
androidTestImplementation 'androidx.test.ext:junit:1.1.5' androidTestImplementation 'androidx.test.ext:junit:1.1.5'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1' androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1'
} }
//room用の依存関係を追加
dependencies {
def room_version = "2.4.1"
implementation "androidx.room:room-runtime:$room_version"
annotationProcessor "androidx.room:room-compiler:$room_version"
}
//Map用の依存関係の追加
dependencies {
implementation 'com.google.android.gms:play-services-maps:18.0.0'
implementation 'com.google.android.gms:play-services-location:18.0.0'
implementation 'com.squareup.okhttp3:okhttp:4.9.3'
implementation 'com.google.code.gson:gson:2.8.9' // Gsonライブラリの追加
}

29
app/google-services.json Normal file
View File

@ -0,0 +1,29 @@
{
"project_info": {
"project_number": "317219128586",
"project_id": "oplogy-b6971",
"storage_bucket": "oplogy-b6971.appspot.com"
},
"client": [
{
"client_info": {
"mobilesdk_app_id": "1:317219128586:android:c29583456e8fbd5f12a6f3",
"android_client_info": {
"package_name": "com.example.oplogy"
}
},
"oauth_client": [],
"api_key": [
{
"current_key": "AIzaSyDaULi2TFHLiscR7DSZBCKS08d76Rtb49c"
}
],
"services": {
"appinvite_service": {
"other_platform_oauth_client": []
}
}
}
],
"configuration_version": "1"
}

View File

@ -2,6 +2,11 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"> xmlns:tools="http://schemas.android.com/tools">
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission
android:name="android.permission.ACCESS_FINE_LOCATION"
tools:ignore="CoarseFineLocation" />
<application <application
android:allowBackup="true" android:allowBackup="true"
android:dataExtractionRules="@xml/data_extraction_rules" android:dataExtractionRules="@xml/data_extraction_rules"
@ -11,8 +16,14 @@
android:roundIcon="@mipmap/ic_launcher_round" android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true" android:supportsRtl="true"
android:theme="@style/Theme.Oplogy" android:theme="@style/Theme.Oplogy"
tools:ignore="ExtraText"
tools:targetApi="31"> tools:targetApi="31">
<activity
android:name=".SettingView"
android:exported="false" />
<activity
android:name=".SetUpActivity"
android:exported="false" />
<!-- <!--
TODO: Before you run your application, you need a Google Maps API key. TODO: Before you run your application, you need a Google Maps API key.
@ -26,22 +37,25 @@
--> -->
<meta-data <meta-data
android:name="com.google.android.geo.API_KEY" android:name="com.google.android.geo.API_KEY"
android:value = "AIzaSyBQ1Ak-I2NL5TP4K59ZI0VgzKk6HNZuusw" /> android:value="AIzaSyBQ1Ak-I2NL5TP4K59ZI0VgzKk6HNZuusw" />
<activity <activity
android:name=".MapsActivity" android:name=".Maps"
android:exported="true" android:exported="false"
android:label="@string/title_activity_maps"> android:label="@string/title_activity_maps" />
<intent-filter> <activity
<action android:name="android.intent.action.MAIN" /> android:name=".SubmissionActivity"
<category android:name="android.intent.category.LAUNCHER" /> android:exported="false" />
</intent-filter> <activity
</activity> android:name=".CreateUUID"
android:exported="false" />
<activity
android:name=".DialogFragment"
android:exported="false" />
<activity <activity
android:name=".MainActivity" android:name=".MainActivity"
android:exported="true"> android:exported="true"
tools:ignore="DuplicateActivity">
<intent-filter> <intent-filter>
<action android:name="android.intent.action.MAIN" /> <action android:name="android.intent.action.MAIN" />

Binary file not shown.

After

Width:  |  Height:  |  Size: 367 KiB

View File

@ -0,0 +1,10 @@
package com.example.oplogy;
import androidx.room.Database;
import androidx.room.RoomDatabase;
@Database(entities = {SetUpTable.class}, version = 2, exportSchema = false)
public abstract class AppDatabase extends RoomDatabase {
// データベースにアクセスするためのメソッドを提供する
public abstract SetUpTableDao setUpTableDao();
}

View File

@ -0,0 +1,39 @@
package com.example.oplogy;
import androidx.room.TypeConverter;
import com.google.firebase.Timestamp;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Locale;
public class Converters {
private static final SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss'Z'", Locale.JAPAN);
// タイムスタンプを文字列(yyyy-mm-dd,日時)に変換
@TypeConverter
public static List<String> fromTimestampList(List<Timestamp> timestamps) {
List<String> stringsList = new ArrayList<>();
for (Timestamp timestamp : timestamps) {
stringsList.add(format.format(timestamp.toDate()));
}
return stringsList;
}
@TypeConverter
public static List<Timestamp> toTimestampList(List<String> strings) {
List<Timestamp> timestamps = new ArrayList<>();
for (String string : strings) {
try {
Date date = format.parse(string);
timestamps.add(new Timestamp(date));
} catch (Exception e) {
e.printStackTrace();
}
}
return timestamps;
}
}

View File

@ -0,0 +1,420 @@
package com.example.oplogy;
import android.content.Context;
import android.content.SharedPreferences;
import android.location.Address;
import android.location.Geocoder;
import android.util.Log;
import androidx.appcompat.app.AppCompatActivity;
import androidx.room.Room;
import com.google.android.gms.maps.model.LatLng;
import com.google.firebase.Timestamp;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.Date;
import java.util.List;
import java.util.Locale;
import java.util.TimeZone;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
//保護者の希望とSetUpActivityによって設定された情報をもとにスケジュールとルートを作成する
public class CreateSchedule {
MyDataClass data;//Firestoreから受け取ったdataを入れる変数
String startPointString;//家庭訪問の開始地点
String startTimeHomeVisitString;//家庭訪問の開始時間
String endTimeHomeVisitString;//家庭訪問の終了時間
String intervalTimeString;//家庭訪問の一家庭当たりの時間
String startBreakTimeString;//家庭訪問の休憩の開始時間
String endBreakTimeString;//家庭訪問の休憩の終了時間
int intervalInt;//家庭訪問の一家庭当たりの時間と移動時間の合計
int startBreakTimeMinutesInt;//家庭訪問の開始時間から休憩時間までの時間
int endBreakTimeMinutesInt;//家庭訪問の休憩終了時間から終了時間までの時間
private final AppDatabase db;
private int arraySizeInt;
private boolean notSecondDuplicatesBoolean;//スケジュールの重複の有無(第一希望日のみで通った場合も考えて初期はtrue)
String[] homeVisitDaysString;
public CreateSchedule(AppCompatActivity activity) {
this.db = Room.databaseBuilder(activity.getApplicationContext(), AppDatabase.class, "SetUpTable").build();
this.notSecondDuplicatesBoolean = true; // 初期値をtrueに設定する
SharedPreferences sharedPreferences = activity.getSharedPreferences("visitingDate", Context.MODE_PRIVATE);
String firstDay = sharedPreferences.getString("day1", null);
String secondDay = sharedPreferences.getString("day2", null);
String thirdDay = sharedPreferences.getString("day3", null);
Log.d("createSchedule","day1"+firstDay+"day2"+secondDay+"thirdday"+thirdDay);
homeVisitDaysString = new String[]{firstDay, secondDay, thirdDay};
}
//MainActivityからデータを受け取る
public String receiveData(List<MyDataClass> myDataList, Context context) {
//myDataListの要素data第一希望日と第二希望日に以下を追加する
//保護者の希望時間帯の長さ
//家庭訪問の日付
//保護者の希望時間帯の開始と終了時間
setData(myDataList);
//希望時間帯の長さ順に並び替える前のログ
outPutLogSort(myDataList);
//保護者の希望時間帯が短い順にmyDataListのDataを並び替える
timeZoneSort(myDataList);
//希望時間帯の長さ順に並び替えたあとのログ
outPutLogSort(myDataList);
ExecutorService executor = Executors.newSingleThreadExecutor();
executor.execute(() -> {
//Roomから以下の情報を取得
//家庭訪問全体の開始時間
//家庭訪問全体の終了時間
//一家庭あたりの家庭訪問の時間
//家庭訪問の休憩開始時間
//家庭訪問の休憩終了時間
getRoomData();
//Roomから取得した情報のログ
outPutLogRoomData();
//以下の情報を計算
//家庭訪問の合計時間
//家庭訪問の開始時間から休憩時間までの分数
//家庭訪問の休憩終了時間から終了時間までの分数
timeCalculation(endTimeHomeVisitString, startBreakTimeString, endBreakTimeString);
//家庭訪問全体のスケジュールの開始時間を要素とした配列の作成(:1200,1220,1240のように各家庭への到着時間となる区切り)とログ表示
int[][][] intervalArrayInt = homeVisitSchedule();
outPutLogIntervalArray(intervalArrayInt);
//スケジュール作成
boolean notDuplicatesBoolean = createSchedule(myDataList, intervalArrayInt);
//スケジュールの重複の確認
if (notDuplicatesBoolean) {
//スケジュールを基準にソートする
sortSchedule(myDataList);
}else{
//第二希望日で同じ処理を行う
Log.d("CreateSchedule", "第二希望");
secondSetData(myDataList);
secondTimeZoneSort(myDataList);
notSecondDuplicatesBoolean = secondCreateSchedule(myDataList, intervalArrayInt);
//スケジュールを基準にソートする
sortSchedule(myDataList);
}
});
// 重複がなければ開始地点の緯度経度を返す
if (notSecondDuplicatesBoolean) {
// 保護者の住所を緯度経度に変換する
String startPointLatLngString = geocodeAddress(myDataList, context);
Log.d("CreateSchedule", "startPointLatLngString" + startPointLatLngString);
outPutLogSchedule(myDataList);
return startPointLatLngString;
} else {
// 重複があるときは""を返す
Log.d("CreateSchedule", "重複によるエラー");
return "";
}
}
private void setData(List<MyDataClass> myDataList) {
for (int i = 0; i < myDataList.size(); i++) {
// 希望時間帯の終了時刻から開始時刻を引いて希望時間帯の長さ(timezone)に入れる
data = myDataList.get(i);
//保護者の第一希望日
List<Timestamp> firstDayList = data.getFirstDay();
//保護者の第一希望日の開始時間
Timestamp parentStartTimestamp = firstDayList.get(0);
//保護者の第一希望日の終了時間
Timestamp parentEndTimestamp = firstDayList.get(1);
//保護者の第一希望日の希望時間帯の長さ
Long timezoneLong = parentEndTimestamp.getSeconds() - parentStartTimestamp.getSeconds();
data.setTimezone(timezoneLong);
// TimeStampを日付に変換
Date startDate = new Date(parentStartTimestamp.getSeconds() * 1000);
Date endDate = new Date(parentEndTimestamp.getSeconds() * 1000);
SimpleDateFormat sdfDateData = new SimpleDateFormat("yyyyMMdd");
sdfDateData.setTimeZone(TimeZone.getTimeZone("Asia/Tokyo"));
//第一希望日の日付
String startDateString = sdfDateData.format(startDate);
String endDateString = sdfDateData.format(endDate);
SimpleDateFormat sdfMinutes = new SimpleDateFormat("HHmm");
sdfMinutes.setTimeZone(TimeZone.getTimeZone("Asia/Tokyo"));
//保護者の希望開始時間を時間表記にしたもの
String parentStartTimeString = sdfMinutes.format(parentStartTimestamp.toDate());
//保護者の希望終了時間を時間表記にしたもの
String parentEndTimeString = sdfMinutes.format(parentEndTimestamp.toDate());
// myDataList の中の data に追加する処理
myDataList.get(i).setTimezone(timezoneLong);
myDataList.get(i).setStartDateString(startDateString);
myDataList.get(i).setEndDateString(endDateString);
myDataList.get(i).setParentStartTimeString(parentStartTimeString);
myDataList.get(i).setParentEndTimeString(parentEndTimeString);
}
}
//setDataと処理は同じ(第二希望は任意なのでその点だけ確認)
private void secondSetData(List<MyDataClass> myDataList) {
for (int i = 0; i < myDataList.size(); i++) {
// 希望時間帯の終了時刻から開始時刻を引いて希望時間帯の長さ(timezone)に入れる
data = myDataList.get(i);
if (myDataList.get(i).getSecondDay() != null) {
//保護者の第二希望日
List<Timestamp> secondDayList = data.getSecondDay();
//保護者の第二希望日の開始時間
Timestamp parentStartTimestamp = secondDayList.get(0);
//保護者の第二希望日の終了時間
Timestamp parentEndTimestamp = secondDayList.get(1);
//保護者の第二希望日の希望時間帯の長さ
Long secondDayTimezoneLong = parentEndTimestamp.getSeconds() - parentStartTimestamp.getSeconds();
data.setTimezone(secondDayTimezoneLong);
// TimeStampを日付に変換
Date startDate = new Date(parentStartTimestamp.getSeconds() * 1000);
Date endDate = new Date(parentEndTimestamp.getSeconds() * 1000);
SimpleDateFormat sdfDateData = new SimpleDateFormat("yyyyMMdd");
sdfDateData.setTimeZone(TimeZone.getTimeZone("Asia/Tokyo"));
//第二希望日の日付
String secondDayStartDateString = sdfDateData.format(startDate);
String secondDaySndDateString = sdfDateData.format(endDate);
SimpleDateFormat sdfMinutes = new SimpleDateFormat("HHmm");
sdfMinutes.setTimeZone(TimeZone.getTimeZone("Asia/Tokyo"));
//保護者の希望開始時間を時間表記にしたもの
String secondDayParentStartTimeString = sdfMinutes.format(parentStartTimestamp.toDate());
//保護者の希望終了時間を時間表記にしたもの
String secondDayParentEndTimeString = sdfMinutes.format(parentEndTimestamp.toDate());
// myDataList の中の data に追加する処理
myDataList.get(i).setSecondDayTimezone(secondDayTimezoneLong);
myDataList.get(i).setSecondDayStartDateString(secondDayStartDateString);
myDataList.get(i).setSecondDayEndDateString(secondDaySndDateString);
myDataList.get(i).setSecondDayParentStartTimeString(secondDayParentStartTimeString);
myDataList.get(i).setSecondDayParentEndTimeString(secondDayParentEndTimeString);
}
}
}
private void timeZoneSort(List<MyDataClass> myDataList) {
// timezoneを比較するComparatortimezoneが短い順に並べる
Comparator<MyDataClass> comparator = Comparator.comparing(MyDataClass::getTimezone);
// myDataListをtimezoneの値でソート
myDataList.sort(comparator);
}
private void secondTimeZoneSort(List<MyDataClass> myDataList) {
// timezoneを比較するComparatortimezoneが短い順に並べる
Comparator<MyDataClass> comparator = Comparator.comparing(MyDataClass::getSecondDayTimezone);
// myDataListをtimezoneの値でソート
myDataList.sort(comparator);
}
private void outPutLogSort(List<MyDataClass> myDataList) {
for (int i = 0; i < myDataList.size(); i++) {
Log.d("CreateSchedule", "(index: " + i + ") data: " + myDataList.get(i).getPatronName());
Log.d("CreateSchedule", "(index: " + i + ") data: " + myDataList.get(i).getClass());
Log.d("CreateSchedule", "(index: " + i + ") timezone: " + myDataList.get(i).getTimezone());
Log.d("CreateSchedule", "(index: " + i + ") startDate: " + myDataList.get(i).getStartDateString());
Log.d("CreateSchedule:outPutLogBeforeSort", "parentStartTimeString: " + myDataList.get(i).getParentStartTimeString());
Log.d("CreateSchedule:outPutLogBeforeSort", "parentEndTimeString: " + myDataList.get(i).getParentEndTimeString());
}
}
private void getRoomData() {
// setUpActivityによって入力されRoomに保存された値を取り出す処理
//Roomの操作の定義
SetUpTableDao setUpTableDao = db.setUpTableDao();
startPointString = setUpTableDao.getStartPoint();
startTimeHomeVisitString = setUpTableDao.getStartTime();
endTimeHomeVisitString = setUpTableDao.getEndTime();
intervalTimeString = setUpTableDao.getIntervalTime();
startBreakTimeString = setUpTableDao.getStartBreakTime();
endBreakTimeString = setUpTableDao.getEndBreakTime();
}
//Roomからのデータ取得に関するログ
void outPutLogRoomData() {
Log.d("CreateSchedule:outPutLogRoomData", "開始時間" + startTimeHomeVisitString);
Log.d("CreateSchedule:outPutLogRoomData", "終了時刻" + endTimeHomeVisitString);
Log.d("CreateSchedule:outPutLogRoomData", "一家庭当たりの所要時間" + intervalTimeString);
Log.d("CreateSchedule:outPutLogRoomData", "休憩開始時刻" + startBreakTimeString);
Log.d("CreateSchedule:outPutLogRoomData", "休憩終了時刻" + endBreakTimeString);
}
private void timeCalculation(String endTimeHomeVisitString, String startBreakTime, String endBreakTime) {
//家庭訪問の合計時間を計算するため家庭訪問の終了時間から開始時間を引いた数を求めている但し(0,2)によって先に1時間単位の差を求めた後に(2,4)によって分単位の差を求めている
int totalTimeInt = ((Integer.parseInt(endTimeHomeVisitString.substring(0, 2)) - (Integer.parseInt(startTimeHomeVisitString.substring(0, 2)))) * 60 + ((Integer.parseInt(endTimeHomeVisitString.substring(2, 4)))) - (Integer.parseInt(startTimeHomeVisitString.substring(2, 4))));
//家庭訪問の休憩開始時間から家庭訪問の開始時間を引くことで家庭訪問の開始から休憩時間までの分数を計算
startBreakTimeMinutesInt = ((Integer.parseInt(startBreakTime.substring(0, 2))) - (Integer.parseInt(startTimeHomeVisitString.substring(0, 2)))) * 60 + ((Integer.parseInt(startBreakTime.substring(2, 4))) - (Integer.parseInt(startTimeHomeVisitString.substring(2, 4))));
//家庭訪問の休憩終了時間から家庭訪問の終了時間を引くことで休憩の終わりから家庭訪問の終了時間までの分数を計算
endBreakTimeMinutesInt = ((Integer.parseInt(endBreakTime.substring(0, 2))) - (Integer.parseInt(startTimeHomeVisitString.substring(0, 2)))) * 60 + ((Integer.parseInt(endBreakTime.substring(2, 4))) - (Integer.parseInt(startTimeHomeVisitString.substring(2, 4))));
intervalInt = Integer.parseInt(intervalTimeString) + 10;//移動時間込みの1家庭当たりの所要時間
arraySizeInt = totalTimeInt / intervalInt;//家庭訪問の合計時間から移動時間込みの1家庭当たりの所要時間を割ることで配列の数を求めている
}
private int[][][] homeVisitSchedule() {
//家庭訪問の開始時間からの経過分数を入れる配列
List<Integer> intervalList = new ArrayList<>();
startBreakTimeMinutesInt = (((Integer.parseInt(startTimeHomeVisitString.substring(0, 2))) + (startBreakTimeMinutesInt + (Integer.parseInt(startTimeHomeVisitString.substring(0, 2)))) / 60) % 24) * 100 + (startBreakTimeMinutesInt + (Integer.parseInt(startTimeHomeVisitString.substring(2, 4)))) % 60;
endBreakTimeMinutesInt = (((Integer.parseInt(startTimeHomeVisitString.substring(0, 2))) + (endBreakTimeMinutesInt + (Integer.parseInt(startTimeHomeVisitString.substring(0, 2)))) / 60) % 24) * 100 + (endBreakTimeMinutesInt + (Integer.parseInt(startTimeHomeVisitString.substring(2, 4)))) % 60;
//休憩時間を除いた家庭訪問の開始時間からの経過分数+家庭訪問の開始時間=家庭訪問のスケジュール区切りをintervalArrayに入れる処理
for (int i = 0; i < arraySizeInt; i++) {
int intervalMinutesInt = (((Integer.parseInt(startTimeHomeVisitString.substring(0, 2))) + (intervalInt * i) / 60) % 24) * 100 + (intervalInt * i) % 60;
if (intervalMinutesInt % 100 >= 60) {
intervalMinutesInt += 40; // 下2桁が60以上の場合は繰り上げる
}
//教師の休憩時間を除く処理
if (intervalMinutesInt < startBreakTimeMinutesInt || intervalMinutesInt >= endBreakTimeMinutesInt) {
intervalList.add(intervalMinutesInt);
}
}
//[3]は家庭訪問の日目
int[][][] intervalArrayInt = new int[3][intervalList.size()][2];
for (int i = 0; i < intervalList.size(); i++) {
for (int j = 0; j < 3; j++) {
intervalArrayInt[j][i][0] = intervalList.get(i);//家庭訪問のスケジュール区切りの時間を要素に入れる
intervalArrayInt[j][i][1] = 0;//家庭訪問のスケジュールにまだ保護者が割り当てられていないことを表す
}
}
return intervalArrayInt;
}
private void outPutLogIntervalArray(int[][][] intervalArrayInt) {
for (int i = 0; i < intervalArrayInt[0].length; i++) {
Log.d("CreateSchedule", "inteintervalArray:(intex:" + i + ") :" + intervalArrayInt[0][i][0]);
}
}
private Boolean createSchedule(List<MyDataClass> myDataList, int[][][] intervalArrayInt) {
for (int i = 0; i < myDataList.size(); i++) {
for (int j = 0; j < intervalArrayInt[0].length - 1; j++) {
for (int x = 0; x < 3; x++) {
//家庭訪問の日目が保護者の第一希望日かを判定する
//まだスケジュールを割り当てていない保護者かを判定する
if (homeVisitDaysString[x].equals(myDataList.get(i).getStartDateString()) && myDataList.get(i).getSchedule() == 0) {
checkSchedule(myDataList, intervalArrayInt, i, j, x, myDataList.get(i).getStartDateString(),homeVisitDaysString);
break;
}
}
}
}
for (int i = 0; i < myDataList.size(); i++) {
if (myDataList.get(i).getSchedule() == 0) {//重複により割り当てがされていない保護者がいないかの確認
return false;
}
}
return true;
}
private boolean secondCreateSchedule(List<MyDataClass> myDataList, int[][][] intervalArrayInt) {
for (int i = 0; i < myDataList.size(); i++) {
for (int j = 0; j < intervalArrayInt[0].length - 1; j++) {
for (int x = 0; x < 3; x++) {
//家庭訪問の日目が保護者の第一希望日かを判定する
//まだスケジュールを割り当てていない保護者かを判定する
if (homeVisitDaysString[x].equals(myDataList.get(i).getSecondDayStartDateString()) && myDataList.get(i).getSchedule() == 0) {
checkSchedule(myDataList, intervalArrayInt, i, j, x, myDataList.get(i).getSecondDayStartDateString(),homeVisitDaysString);
}
}
}
}
for (int i = 0; i < myDataList.size(); i++) {
if (myDataList.get(i).getSchedule() == 0) {//重複により割り当てがされていない保護者がいないかの確認
return false;
}
}
return true;
}
private void checkSchedule(List<MyDataClass> myDataList, int[][][] intervalArrayInt, int i, int j, int x, String desiredDateString, String[] homeVisitDaysString) {
//保護者の希望時間の開始と終了の間にまだ保護者の割り当てがされていないスケジュールの空き時間があるかの判定
if (intervalArrayInt[x][j][0] >= Integer.parseInt(myDataList.get(i).getParentStartTimeString()) && intervalArrayInt[x][j + 1][0] <= Integer.parseInt(myDataList.get(i).getParentEndTimeString()) && intervalArrayInt[x][j][1] == 0) {
intervalArrayInt[x][j][1] += 1;//その時間が割り当て済みでありこと
myDataList.get(i).setScheduleDay(homeVisitDaysString[x]);
Log.d("CreateSchedule","getScheduleDay"+myDataList.get(i).getScheduleDay());
myDataList.get(i).setSchedule(Integer.parseInt(desiredDateString.substring(4, 8) + intervalArrayInt[x][j][0]));//スケジュールをmyDataListに入れる(:6041240(6月4日12時40分))
}
}
private void sortSchedule(List<MyDataClass> myDataList) {
Comparator<MyDataClass> comparator = Comparator.comparing(MyDataClass::getSchedule);
//スケジュールを元にmyDataListをソートする
myDataList.sort(comparator);
}
private String geocodeAddress(List<MyDataClass> myDataList, Context context) {
try {
Geocoder geocoder = new Geocoder(context, Locale.getDefault());
for (int i = 0; i < myDataList.size(); i++) {
List<Address> addressesList = geocoder.getFromLocationName(myDataList.get(i).getAddress().toString(), 1);
if (addressesList != null && !addressesList.isEmpty()) {
Address addressResult = addressesList.get(0);
//保護者の住所を緯度経度に変換する
double latitudeDouble = addressResult.getLatitude();
double longitudeDouble = addressResult.getLongitude();
//保護者の住所の緯度経度をmyDataListに追加する
myDataList.get(i).setLatLngString(String.valueOf(new LatLng(latitudeDouble, longitudeDouble)));
}
}
//SetUpで設定した家庭訪問の開始地点を緯度経度に変換
String startPointLatLngString = String.valueOf(geocoder.getFromLocationName(startPointString, 1));
String[] startPointLatLngArray = startPointLatLngString.split(",");
if (startPointLatLngArray.length >= 3) {
//[Address[addressLines=[0:"日本、〒510-8102 三重県三重郡朝日町小向852−1"],feature=,admin=三重県,sub-admin=三重郡,locality=朝日町,thoroughfare=null,postalCode=510-8102,countryCode=JP,countryName=日本,hasLatitude=true,latitude=35.0351632,hasLongitude=true,longitude=136.66538770000003,phone=null,url=null,extras=null]]
//というようになっているので配列の後ろから6番目が緯度4番目が経度
//不要なlatitude=とlongitude=を取り除く
String latitude = startPointLatLngArray[startPointLatLngArray.length - 6].trim().replace("latitude=", "");
String longitude = startPointLatLngArray[startPointLatLngArray.length - 4].trim().replace("longitude=", "");
Log.d("CreateSchedule", "Latitude: " + latitude + ", Longitude: " + longitude);
// 文字列を結合して形式を整える
startPointLatLngString = latitude + "," + longitude;
Log.d("CreateSchedule", "startPointLatLngString: " + startPointLatLngString);
return startPointLatLngString;
}
} catch (IOException e) {
Log.e("CreateSchedule", "緯度経度の取得に失敗: " + e);
}
return null;
}
private void outPutLogSchedule(List<MyDataClass> myDataList) {
for (int i = 0; i < myDataList.size(); i++) {
Log.d("CreateSchedule:outPutLogSchedule", "(index: " + i + ") data: " + myDataList.get(i));
Log.d("CreateSchedule:outPutLogSchedule", "(index: " + i + ") Schedule: " + myDataList.get(i).getSchedule());
Log.d("CreateSchedule", "(index: " + i + ") LatLng" + myDataList.get(i).getLatLngString());
}
}
}

View File

@ -0,0 +1,28 @@
package com.example.oplogy;
import java.util.List;
public class CreateUUID {
public static int generateUUID(List<Integer> classIdList) {
while (true) {
int uuidInt = (int) (Math.random() * 1000000);
boolean isDuplicate = false;
for (int classIdInt : classIdList) {
if (classIdInt == uuidInt) {
//重複があればフラグを立てループを抜ける
isDuplicate = true;
break;
}
}
//重複がなければ生成したUUIDを返す
if (!isDuplicate) {
//firestoreに挿入処理
InsertClassIdforFirebase insertClassIdforFirebase = new InsertClassIdforFirebase();
insertClassIdforFirebase.insertClassId(uuidInt);
return uuidInt;
}
}
}
}

View File

@ -0,0 +1,35 @@
package com.example.oplogy;
import android.app.DatePickerDialog;
import android.app.Dialog;
import android.os.Bundle;
import android.widget.DatePicker;
import androidx.annotation.NonNull;
import androidx.fragment.app.DialogFragment;
import java.util.Calendar;
public class DatePick extends DialogFragment implements
DatePickerDialog.OnDateSetListener {
@NonNull
@Override
public Dialog onCreateDialog(Bundle savedInstantState) {
//デフォルトのタイムゾーンおよびロケールを使用してカレンダを取得
final Calendar c = Calendar.getInstance();
int yearInt = c.get(Calendar.YEAR);
int monthInt = c.get(Calendar.MONTH);
int dayInt = c.get(Calendar.DAY_OF_MONTH);
return new DatePickerDialog(requireActivity(), (DatePickerDialog.OnDateSetListener) getActivity(), yearInt, monthInt, dayInt);
}
@Override
public void onDateSet(DatePicker datePicker, int yearInt, int monthInt, int dayInt) {
}
}

View File

@ -0,0 +1,13 @@
package com.example.oplogy;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
public class DialogFragment extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.dialog_fragment);
}
}

View File

@ -0,0 +1,81 @@
package com.example.oplogy;
import android.util.Log;
import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
import com.google.firebase.Timestamp;
import com.google.firebase.firestore.CollectionReference;
import com.google.firebase.firestore.FirebaseFirestore;
import com.google.firebase.firestore.QueryDocumentSnapshot;
import com.google.firebase.firestore.QuerySnapshot;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
public class FirestoreReception {
//firestoreから受け取ったデータを束ねるためのマップ
public List<MyDataClass> myDataList = new ArrayList<>();
private FirebaseFirestore db;
public FirestoreReception() {
db = FirebaseFirestore.getInstance();
}
//ClassIdを引数にデータの作成を行う
public void getDocumentsByClassId(int classId) {
myDataList.clear();
CollectionReference collectionRef = db.collection("QuestionForm");
collectionRef.whereEqualTo("classId", classId).get()
.addOnCompleteListener(new OnCompleteListener<QuerySnapshot>() {
@Override
public void onComplete(Task<QuerySnapshot> task) {
if (task.isSuccessful()) {
// データの取得に成功した場合
for (QueryDocumentSnapshot document : task.getResult()) {
Map<String, Object> data = document.getData();
// ドキュメントのデータをMyDataClassのインスタンスにマッピング
MyDataClass myData = new MyDataClass(
(String) data.get("patronName"),
((Long) data.get("classId")).intValue(),
(List<String>) data.get("address"),
(List<Timestamp>) data.get("firstDay"),
((Long) data.get("studentNumber")).intValue(),
(String) data.get("childName"),
(List<Timestamp>) data.get("thirdDay"),
(List<Timestamp>) data.get("secondDay")
);
//リストに追加
myDataList.add(myData);
}
//取得したデータをログ表示
for (MyDataClass data : myDataList) {
Log.i("FirestoreReceptiond", "data: " + data.toString());
}
} else {
Log.w("FirestoreReceptiond", "Error getting documents.", task.getException());
}
Log.i("FirestoreReceptiond", "data: " + myDataList.size());
}
});
}
//Dataのリストのサイズを返す
public int getMyDataListSize() {
return myDataList.size();
}
//Dataのリストを返す
public List<MyDataClass> getMyDataList() {
return myDataList;
}
}

View File

@ -0,0 +1,48 @@
package com.example.oplogy;
import android.util.Log;
import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
import com.google.firebase.firestore.FirebaseFirestore;
import com.google.firebase.firestore.QueryDocumentSnapshot;
import com.google.firebase.firestore.QuerySnapshot;
import org.checkerframework.checker.nullness.qual.NonNull;
import java.util.ArrayList;
import java.util.List;
public class FirestoreReception_classIdDatabase {
private FirebaseFirestore db;
private List<Integer> classIdList= new ArrayList<>();
public FirestoreReception_classIdDatabase() {
db = FirebaseFirestore.getInstance();
}
public List<Integer> getAllDocumentsFromClassIdDatabase() {
db.collection("classId_Database")
.get()
.addOnCompleteListener(new OnCompleteListener<QuerySnapshot>() {
@Override
public void onComplete(@NonNull Task<QuerySnapshot> task) {
if (task.isSuccessful()) {
for (QueryDocumentSnapshot document : task.getResult()) {
Log.d("結果", document.getId() + " => " + document.getData());
//データをListに追加
classIdList.add(((Long) document.get("classId")).intValue());
}
} else {
Log.d("結果", "Error getting documents: ", task.getException());
}
}
});
return classIdList;
}
public List<Integer> getClassIdList() {
return classIdList;
}
}

View File

@ -0,0 +1,19 @@
package com.example.oplogy;
import com.google.firebase.firestore.FirebaseFirestore;
import java.util.HashMap;
import java.util.Map;
public class InsertClassIdforFirebase {
public void insertClassId(int classId) {
FirebaseFirestore db = FirebaseFirestore.getInstance();
Map<String, Object> data = new HashMap<>();
data.put("classId", classId); // classId is inserted as a number
db.collection("classId_Database").add(data)
.addOnSuccessListener(documentReference -> System.out.println("DocumentSnapshot added with ID: " + documentReference.getId()))
.addOnFailureListener(e -> System.err.println("Error adding document: " + e));
}
}

View File

@ -1,153 +1,393 @@
package com.example.oplogy; package com.example.oplogy;
import androidx.annotation.NonNull; import android.app.ProgressDialog;
import androidx.appcompat.app.AppCompatActivity; import android.content.Intent;
import android.content.SharedPreferences;
import android.annotation.SuppressLint; import android.os.Bundle;
import androidd.os.Bunle;
import android.util.Log; import android.util.Log;
import android.view.View; import android.view.View;
import android.widget.Button; import android.widget.ImageView;
import android.widget.EditText;
import android.widget.TextView; import android.widget.TextView;
import android.widget.Toast;
import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;
import androidx.room.Room;
import com.google.android.gms.tasks.OnFailureListener;
import com.google.android.gms.tasks.OnSuccessListener;
import com.google.firebase.firestore.DocumentReference;
import com.google.firebase.firestore.DocumentSnapshot;
import com.google.firebase.firestore.FirebaseFirestore; import com.google.firebase.firestore.FirebaseFirestore;
import com.google.firebase.firestore.QueryDocumentSnapshot; import com.google.gson.Gson;
import java.util.HashMap;
import java.util.Map;
public class MainActivity extends AppCompatActivity {
private TextView textView;
private Button btnShow;
private Button btnAdd;
private EditText number;
private EditText address;
private EditText date;
private EditText time;
private FirebaseFirestore db = FirebaseFirestore.getInstance();
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class MainActivity extends AppCompatActivity implements View.OnClickListener { public class MainActivity extends AppCompatActivity implements View.OnClickListener {
Button button; // ダイアログの宣言
// TextView textView; private AlertDialog alertDialog;
EditText editText; // ID作成のTextViewとImageView
@SuppressLint("MissingInflatedId") private TextView root;
private ImageView imageRoot;
// 提出状況のTextViewとImageView
private TextView submission;
private ImageView imageSubmission;
private TextView SettingView;
private ImageView imageSettingView;
//firestoreの受信関連
private FirebaseFirestore db;
private FirestoreReception firestoreReception;
//取得するためのクラスID
private int classId;
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); setContentView(R.layout.main);
textView=findViewById(R.id.showText); // ルート作成用のインテント
btnShow=findViewById(R.id.btnShow); root = findViewById(R.id.root);
btnAdd=findViewById(R.id.btnAdd); root.setOnClickListener(this);
imageRoot = findViewById(R.id.imageRoot);
imageRoot.setOnClickListener(this);
number=findViewById(R.id.editNumber); // 提出状況のインテント
address=findViewById(R.id.editAddress); submission = findViewById(R.id.submission);
date=findViewById(R.id.editDate); submission.setOnClickListener(this);
time=findViewById(R.id.editTime); imageSubmission = findViewById(R.id.imageSubmission);
imageSubmission.setOnClickListener(this);
// 設定用のインテント
SettingView = findViewById(R.id.setting);
SettingView.setOnClickListener(this);
imageSettingView = findViewById(R.id.imageSetting);
imageSettingView.setOnClickListener(this);
// firestoreの受信関連
db = FirebaseFirestore.getInstance();
firestoreReception = new FirestoreReception();
Log.d("MainActivity", "geocodeAddress");
//データの追加(適当なデータを追加しています実際にはデータベースに保存したいデータを追加してください) ExecutorService executor = Executors.newSingleThreadExecutor();
executor.execute(() -> {
try {
AppDatabase db = getDatabaseInstance();
SetUpTableDao setUpTableDao = db.setUpTableDao();
classId = setUpTableDao.getClassId();
firestoreReception.getDocumentsByClassId(classId);
} catch (Exception e) {
//無視して続行
e.printStackTrace();
}
findViewById(R.id.btnAdd).setOnClickListener(new View.OnClickListener() { });
@Override
public void onClick(View v) { }
User user = new User(number.getText().toString(), address.getText().toString(),date.getText().toString(),time.getText().toString());
db.collection("users") // クリック処理
.add(user) @Override
.addOnSuccessListener(documentReference -> Log.d("@FB1", "DocumentSnapshot added with ID: " + documentReference.getId())) public void onClick(View view) {
.addOnFailureListener(e -> Log.w("@FB1", "Error adding document", e)); // ルート作成のクリック処理
if (view == root) {
imageRoot.setImageResource(R.drawable.pin);
checkSetupAndCreateRoute(this::fetchDataAndCreateRoute);
}
if (view == imageRoot) {
imageRoot.setImageResource(R.drawable.pin);
checkSetupAndCreateRoute(this::fetchDataAndCreateRoute);
}
// 提出状況のクリック処理
if (view == submission) {
checkSetupAndCreateRoute(() -> {
ArrayList<SubmissionStudent> submissionStudents = getSubmissionStudents();
Intent toSubmission = new Intent(MainActivity.this, SubmissionActivity.class);
toSubmission.putParcelableArrayListExtra("submissionStudents", submissionStudents);
startActivity(toSubmission);
});
}
if (view == imageSubmission) {
checkSetupAndCreateRoute(() -> {
ArrayList<SubmissionStudent> submissionStudents = getSubmissionStudents();
Intent toSubmission = new Intent(MainActivity.this, SubmissionActivity.class);
toSubmission.putParcelableArrayListExtra("submissionStudents", submissionStudents);
startActivity(toSubmission);
});
}
if (view == SettingView) {
Intent toSettingView = new Intent(MainActivity.this, SettingView.class);
startActivity(toSettingView);
}
if (view == imageSettingView) {
Intent toSettingView = new Intent(MainActivity.this, SettingView.class);
startActivity(toSettingView);
}
}
//ルート作成提出状況の遷移を行う前のチェックを行う処理
private void checkSetupAndCreateRoute(Runnable onSetupComplete) {
if (isClassIdSet()) {
isSetupExists(classId).thenAccept(setupExists -> {
if (setupExists) {
runOnUiThread(onSetupComplete);
} else {
runOnUiThread(() -> {
Toast.makeText(this, "先に設定画面で情報を入力してください", Toast.LENGTH_SHORT).show();
});
}
}).exceptionally(ex -> {
ex.printStackTrace();
runOnUiThread(() -> {
Toast.makeText(this, "エラーが発生しました", Toast.LENGTH_LONG).show();
});
return null;
});
} else {
Toast.makeText(this, "先に設定画面で情報を入力してください", Toast.LENGTH_SHORT).show();
}
}
// クラスIDが設定されているかどうかを判定
private boolean isClassIdSet() {
// classIdが0より大きい場合trueを返す
return classId > 0;
}
// セットアップが存在するかどうかを判定
private CompletableFuture<Boolean> isSetupExists(int classId) {
final ExecutorService executorService = Executors.newSingleThreadExecutor();
return CompletableFuture.supplyAsync(() -> {
AppDatabase db = getDatabaseInstance();
SetUpTableDao setUpTableDao = db.setUpTableDao();
//データベースの値を全取得
List<SetUpTable> checkData = setUpTableDao.getAll();
for (SetUpTable setUpTable : checkData) {
//SetUpTableのclassIdと引数のclassIdが一致する場合trueを返す
if (setUpTable.classId == classId) {
return true;
}
}
return false;
//処理完了時にexecutorServiceをシャットダウン
}, executorService).whenComplete((result, throwable) -> executorService.shutdown());
}
//ルート作成の非同期処理
private void fetchDataAndCreateRoute() {
ExecutorService executor = Executors.newSingleThreadExecutor();
executor.execute(() -> {
AppDatabase db = getDatabaseInstance();
SetUpTableDao setUpTableDao = db.setUpTableDao();
int totalStudentInt = setUpTableDao.getTotalStudent();
int myDataListSizeInt = firestoreReception.getMyDataListSize();
//総生徒数と提出済みになっている生徒の数が一致するかの確認
runOnUiThread(() -> {
if (totalStudentInt != myDataListSizeInt) {
//未提出者がいることの警告ダイアログ
showRouteCreationDialog();
} else {
//ルート作成
createRoute(executor);
}
});
});
// `fetchDataAndCreateRoute`メソッド内ではshutdownを呼び出さない
}
// 未提出者がいることの警告ダイアログ
private void showRouteCreationDialog() {
new AlertDialog.Builder(MainActivity.this)
.setTitle("警告")
.setMessage("人数が足りてませんがそれでもルート作成を行いますか?")
.setPositiveButton("OK", (dialog, which) -> {
// 新しいExecutorServiceを作成してタスクを実行
ExecutorService dialogExecutor = Executors.newSingleThreadExecutor();
createRoute(dialogExecutor);
dialogExecutor.shutdown();
})
.setNegativeButton("Cancel", (dialog, which) -> {
dialog.dismiss();
})
.show();
}
// ルート作成の非同期処理
private void createRoute(ExecutorService executor) {
// ProgressDialogを作成
ProgressDialog progressDialog = new ProgressDialog(MainActivity.this);
progressDialog.setMessage("Loading...");
progressDialog.setCancelable(false);
progressDialog.show();
executor.execute(() -> {
List<MyDataClass> myDataList = null;
while (myDataList == null) {
myDataList = firestoreReception.getMyDataList();
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
runOnUiThread(progressDialog::dismiss); // 進行状況ダイアログを閉じる
return;
}
}
//final宣言することによってスレッドセーフになる(ラムダ式内で使えるようにする)
final List<MyDataClass> finalMyDataList = myDataList;
CreateSchedule createSchedule = new CreateSchedule(MainActivity.this);
String startPointLatLngString = createSchedule.receiveData(myDataList, getApplicationContext());
Boolean notDuplicatesBoolean = null;
for (int i = 0; i < myDataList.size(); i++) {
if (myDataList.get(i).getSchedule() == 0) {
notDuplicatesBoolean = false;
break;
} else {
notDuplicatesBoolean = true;
}
}
Boolean finalNotDuplicatesBoolean = notDuplicatesBoolean;
Log.d("MainActivity", "重複判定" + String.valueOf(finalNotDuplicatesBoolean));
runOnUiThread(() -> {
progressDialog.dismiss(); // 進行状況ダイアログを閉じる
if (finalNotDuplicatesBoolean) {
Log.d("MainActivity", "スケジュール作成成功");
saveMyDataList(finalMyDataList);
Intent toRoot = new Intent(MainActivity.this, Maps.class);
toRoot.putExtra("startPointLatLngString", startPointLatLngString);
startActivity(toRoot);
} else {
// 保護者の重複による警告ダイアログ
showErrorDialog(finalMyDataList);
}
});
// createRouteの最後にexecutorをシャットダウン
executor.shutdown();
});
}
// 作成したルートを(Mapに渡せるように)保存するメソッド
private void saveMyDataList(List<MyDataClass> myDataList) {
// 共有プリファレンスのインスタンスを取得
SharedPreferences sharedPreferences = getSharedPreferences("MyDataList", MODE_PRIVATE);
SharedPreferences.Editor editor = sharedPreferences.edit();
// MyDataListをJSON形式に変換
Gson gson = new Gson();
String jsonString = gson.toJson(myDataList);
// JSON形式のデータを共有プリファレンスに保存
editor.putString("myDataList", jsonString);
editor.apply();
}
// 保護者の重複による警告ダイアログ
private void showErrorDialog(List<MyDataClass> myDataList) {
List<Integer> studentNumbers = new ArrayList<>();
for (MyDataClass data : myDataList) {
if (data.getSchedule() == 0) {
studentNumbers.add(data.getStudentNumber());
}
}
StringBuilder message = new StringBuilder("保護者の重複が重大でルート作成ができません。保護者に連絡して調整してください。\n\n");
for (int i = 0; i < studentNumbers.size(); i++) {
message.append("出席番号:" + studentNumbers.get(i));
message.append("\n保護者名:" + myDataList.get(i).getPatronName());
message.append("\n第一希望 " + myDataList.get(i).getStartDateString().substring(4, 6) + "");
message.append(myDataList.get(i).getStartDateString().substring(6, 8) + "");
message.append(" " + myDataList.get(i).getParentStartTimeString().substring(0, 2));
message.append(":" + myDataList.get(i).getParentStartTimeString().substring(2, 4));
message.append("" + myDataList.get(i).getParentEndTimeString().substring(0, 2));
message.append(":" + myDataList.get(i).getParentEndTimeString().substring(2, 4));
message.append("\n第二希望 " + myDataList.get(i).getSecondDayStartDateString().substring(4, 6) + "");
message.append(myDataList.get(i).getSecondDayStartDateString().substring(6, 8) + "");
message.append(" " + myDataList.get(i).getSecondDayParentStartTimeString().substring(0, 2));
message.append(":" + myDataList.get(i).getSecondDayParentStartTimeString().substring(2, 4));
message.append("" + myDataList.get(i).getSecondDayParentEndTimeString().substring(0, 2));
message.append(":" + myDataList.get(i).getSecondDayParentEndTimeString().substring(2, 4) + "\n\n");
}
new AlertDialog.Builder(MainActivity.this)
.setTitle("警告")
.setMessage(message.toString())
.setPositiveButton("OK", (dialog, which) -> {
dialog.dismiss();
})
.show();
}
// データベースのインスタンスを取得するメソッド
private AppDatabase getDatabaseInstance() {
return Room.databaseBuilder(getApplicationContext(), AppDatabase.class, "SetUpTable").build();
}
//提出状況の取得
public ArrayList<SubmissionStudent> getSubmissionStudents() {
ArrayList<SubmissionStudent> submissionStudents = new ArrayList<>();
List<MyDataClass> myDataList = firestoreReception.getMyDataList();
ExecutorService executor = Executors.newSingleThreadExecutor();
CountDownLatch latch = new CountDownLatch(1);
executor.execute(() -> {
try {
// 1. Roomデータベースから全生徒数を取得
AppDatabase db = getDatabaseInstance();
SetUpTableDao setUpTableDao = db.setUpTableDao();
int totalStudentInt = setUpTableDao.getTotalStudent();
// 2. Firestoreから生徒番号のリストを取得
ArrayList<Integer> firestoreStudentNumbersList = new ArrayList<>();
for (MyDataClass myData : myDataList) {
int studentNumberInt = myData.getStudentNumber();
firestoreStudentNumbersList.add(studentNumberInt);
}
// 3. SubmissionStudentオブジェクトのリストを作成
for (int i = 1; i <= totalStudentInt; i++) {
boolean submitted = firestoreStudentNumbersList.contains(i);
submissionStudents.add(new SubmissionStudent(i, submitted));
}
} catch (Exception e) {
e.printStackTrace(); // ログにエラーメッセージを出力
} finally {
// 4. データベース操作が完了したことを通知
latch.countDown();
} }
}); });
try {
latch.await(); // 非同期処理が完了するまで待機
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
executor.shutdown(); // ExecutorServiceをシャットダウン
}
btnShow.setOnClickListener(v -> { return submissionStudents;
// Read Data
// Firestoreのコレクションusersのドキュメント一覧を取得する
// 非同期で取得処理が動作する結果を受け取るために処理完了時のリスナーをセットする
db.collection("users").get().addOnCompleteListener(task -> {
String data = "";
if (task.isSuccessful()) {
for (QueryDocumentSnapshot document : task.getResult()) {
Log.d("@FB1", document.getId() + "=>" + document.getData());
User user = document.toObject(User.class);
data += user + "\n";
}
} else {
data = "Error getting documents." + task.getException().getMessage();
}
textView.setText(data);//編集したデータを画面下部に表示
});
});
findViewById(R.id.mapmapcreate).setOnClickListener(
view->{
}
);
} }
@Override @Override
public void onClick(View v) { protected void onDestroy() {
super.onDestroy();
if (alertDialog != null && alertDialog.isShowing()) {
alertDialog.dismiss();
}
} }
}
class User {
private String number;
private String address;
private String date;
private String time;
public User() {
}
public User(String number, String address, String data, String time) {
this.number = number;
this.address = address;
this.date = data;
this.time = time;
}
//getterとsetter
public String getNumber() {
return number;
}
public String getAddress() {
return address;
}
public String getDate() {
return date;
}
public String getTime() {
return time;
}
public void setNumber(String number) {
this.number = number;
}
public void setAddress(String address) {
this.address = address;
}
public void setDate(String date) {
this.date = date;
}
public void setTime(String time) {
this.time = time;
}
} }

View File

@ -0,0 +1,504 @@
package com.example.oplogy;
import android.content.SharedPreferences;
import android.graphics.Color;
import android.graphics.drawable.ShapeDrawable;
import android.graphics.drawable.shapes.OvalShape;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Spinner;
import android.widget.TextView;
import androidx.fragment.app.FragmentActivity;
import com.example.oplogy.databinding.MapsBinding;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.BitmapDescriptorFactory;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.Marker;
import com.google.android.gms.maps.model.MarkerOptions;
import com.google.android.gms.maps.model.PolylineOptions;
import com.google.common.reflect.TypeToken;
import com.google.gson.Gson;
import com.google.gson.JsonArray;
import com.google.gson.JsonObject;
import com.google.gson.JsonPrimitive;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.lang.reflect.Type;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class Maps extends FragmentActivity implements OnMapReadyCallback, View.OnClickListener, GoogleMap.OnMarkerClickListener {
//GoogleMapAPiで使用可能な色
private static final int[] COLORS = new int[]{Color.parseColor("#007FFF"), // HUE_AZURE
Color.parseColor("#0000FF"), // HUE_BLUE
Color.parseColor("#00FFFF"), // HUE_CYAN
Color.parseColor("#00FF00"), // HUE_GREEN
Color.parseColor("#FF00FF"), // HUE_MAGENTA
Color.parseColor("#FFA500"), // HUE_ORANGE
Color.parseColor("#FF0000"), // HUE_RED
Color.parseColor("#FF007F"), // HUE_ROSE
Color.parseColor("#8A2BE2"), // HUE_VIOLET
Color.parseColor("#FFFF00") // HUE_YELLOW
};
private final List<LatLng> latLngList = new ArrayList<>();
private final List<String> nameList = new ArrayList<>();
private final List<Integer> colorList = new ArrayList<>();
private final Map<String, Runnable> dateMap = new HashMap<>();
ImageView backMain;
private GoogleMap mMap;
private LinearLayout locationsName;
private int colorIndex = 0;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// バインディングの設定
com.example.oplogy.databinding.MapsBinding binding = MapsBinding.inflate(getLayoutInflater());
setContentView(binding.getRoot());
// マップフラグメントの設定
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map);
mapFragment.getMapAsync(this);
// 各UI要素の設定
backMain = findViewById(R.id.BackMain);
backMain.setOnClickListener(this);
locationsName = findViewById(R.id.locationsName);
// スピナーの設定
String dateDataString = formatDate(getSharedPreferencesData(0)) + "/" + formatDate(getSharedPreferencesData(1)) + "/" + formatDate(getSharedPreferencesData(2));
ArrayAdapter<String> adapter = new ArrayAdapter<>(this, android.R.layout.simple_spinner_item);
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
String[] dates = dateDataString.split("/");
for (String date : dates) {
adapter.add(date);
}
// 各日付に対応するRunnableを設定する
for (int i = 0; i < 3; i++) {
int finalI = i;
String dayString = getSharedPreferencesData(i);
String formattedDayString = formatDate(dayString);
dateMap.put(formattedDayString, () -> loadMapAndNames(createlocationData(finalI), getscrollViewlData(finalI)));
}
Spinner dateSpinner = findViewById(R.id.date);
dateSpinner.setAdapter(adapter);
// スピナーのアイテム選択リスナーを設定
dateSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
String selectedItemString = (String) parent.getItemAtPosition(position);
Runnable mapLoader = dateMap.get(selectedItemString);
if (mapLoader != null) {
mapLoader.run();
}
}
@Override
public void onNothingSelected(AdapterView<?> parent) {
// Do nothing
}
});
}
//ルート表示を押して最初に表示されるルート(3日間の家庭訪問における1日目)の設定
@Override
public void onMapReady(GoogleMap googleMap) {
//Google mapの定義
mMap = googleMap;
mMap.setOnMarkerClickListener(this);
//家庭訪問1日目のスケジュール順に緯度経度の情報をString型の変数に格納
//35.1711355,136.88552149999998/35.1696089,136.884084/35.1732838,136.88832890000003/...
String locationDataString = createlocationData(0);
//家庭訪問1日目のスケジュール順に住所や出席番号家庭訪問の開始時間の情報をString型の変数に格納
//開始地点/出席番号2番:鈴木次郎<453-0015 愛知県名古屋市中村区椿町6 地下1階5階> 06月04日12時00分/...
String scrollViewlDataString = getscrollViewlData(0);
loadMapAndNames(locationDataString, scrollViewlDataString);
}
//家庭訪問の日目が何月何日かを返すメソッド
private String getSharedPreferencesData(int i) {
SharedPreferences sharedPreferences = getSharedPreferences("visitingDate", MODE_PRIVATE);
// SetUpで設定した8桁の数字表記の家庭訪問日を日付表記に変更
String dayString;
if (i == 0) {
dayString = sharedPreferences.getString("day1", null);
} else if (i == 1) {
dayString = sharedPreferences.getString("day2", null);
} else {
dayString = sharedPreferences.getString("day3", null);
}
return dayString;
}
//家庭訪問の日付を8桁の整数表記から(2024070707月07日)表記に変更する
private String formatDate(String date) {
if (date == null || date.length() != 8) {
return "";
}
String monthString = date.substring(4, 6);
String dayString = date.substring(6, 8);
return monthString + "" + dayString + "";
}
//家庭訪問1日目のスケジュール順に緯度経度の情報をString型の変数に格納
private String createlocationData(int i) {
//家庭訪問の開始地点の緯度経度
String startPointLatLngString = getIntent().getStringExtra("startPointLatLngString");
List<MyDataClass> myDataList = getMyDataList();
//家庭訪問の緯度経度情報をまとめる変数
StringBuilder latlngString = new StringBuilder();
for (int y = -1; y < myDataList.size(); y++) {
if (y < 0) {
//家庭訪問の開始地点を追加
latlngString.append(startPointLatLngString);
} else if (myDataList.get(y).getScheduleDay().equals(getSharedPreferencesData(i))) {
if (latlngString.length() > 0) {
//区切りのスラッシュ
latlngString.append("/");
}
//mydataListから取り出した家庭訪問の各家庭の住所の緯度経度を追加
//この時点ではlongitude latitudeのような不要な文字があるのでformatLatLngメソッドで緯度経度だけのデータにする
latlngString.append(formatLatLng(myDataList.get(y)));
}
}
//各家庭の緯度経度をまとめたものを返す
return latlngString.toString();
}
//緯度と経度は(35.1711355,136.88552149999998)のように()の中に入っているのでそこだけを取り出す
private String formatLatLng(MyDataClass myData) {
String latlngString = myData.getLatLngString();
int startIndex = latlngString.indexOf("(") + 1;
int endIndex = latlngString.indexOf(")");
return latlngString.substring(startIndex, endIndex);
}
//ScrollViewにて表示するdataの作成メソッド
private String getscrollViewlData(int i) {
List<MyDataClass> myDataList = getMyDataList();
String homeVisitDataString = "";
for (int y = -1; y < myDataList.size(); y++) {
if (y < 0) {
//家庭訪問の開始地点
homeVisitDataString += "開始地点/";
} else if (myDataList.get(y).getScheduleDay().equals(getSharedPreferencesData(i)) && y + 1 < myDataList.size()) {
//出席番号:生徒の名前 <住所> 家庭訪問の開始時間+/
homeVisitDataString += "出席番号" + String.valueOf(myDataList.get(y).getStudentNumber()) + "番:" + myDataList.get(y).getChildName() + "<" + myDataList.get(y).getAddress().get(0) + "> " + formatSchedule(String.valueOf(myDataList.get(y).getSchedule())) + "/";
} else if (myDataList.get(y).getScheduleDay().equals(getSharedPreferencesData(i))) {
homeVisitDataString += "出席番号" + String.valueOf(myDataList.get(y).getStudentNumber()) + "番:" + myDataList.get(y).getChildName() + " <" + myDataList.get(y).getAddress().get(0) + "> " + formatSchedule(String.valueOf(myDataList.get(y).getSchedule()));
}
}
return homeVisitDataString;
}
//家庭訪問のscheduleを7桁の整数から(604120006月12日05時20分)に変換
private String formatSchedule(String schedule) {
Log.d("Maps", "schedule: " + schedule);
if (schedule.length() != 7) {
schedule = "0" + schedule;
String monthString = schedule.substring(0, 2);
String dayString = schedule.substring(2, 4);
String hourString = "0" + schedule.substring(4, 5);
String minuteString = schedule.substring(5, 7);
return monthString + "" + dayString + "" + hourString + "" + minuteString + "";
} else {
String monthString = "0" + schedule.substring(0, 1);
String dayString = schedule.substring(1, 3);
String hourString = schedule.substring(3, 5);
String minuteString = schedule.substring(5, 7);
return monthString + "" + dayString + "" + hourString + "" + minuteString + "";
}
}
// 共有プリファレンスからMyDataListを取得するメソッド
private List<MyDataClass> getMyDataList() {
// 共有プリファレンスのインスタンスを取得
SharedPreferences sharedPreferences = getSharedPreferences("MyDataList", MODE_PRIVATE);
// 共有プリファレンスからJSON形式のデータを取得
String jsonString = sharedPreferences.getString("myDataList", "");
// JSON形式のデータをMyDataListに変換
Gson gson = new Gson();
Type type = new TypeToken<List<MyDataClass>>() {
}.getType();
List<MyDataClass> myDataList = gson.fromJson(jsonString, type);
return myDataList;
}
//mapやgetscrollViewlに値を渡すハブの役割のメソッド
private void loadMapAndNames(String locationData, String nameData) {
try {
//mapに関するすべてのデータをリセット
latLngList.clear();
nameList.clear();
colorList.clear();
locationsName.removeAllViews();
mMap.clear();
// locationDataをスラッシュで分割して緯度経度リストを取得
String[] locArrayString = locationData.split("/");
// nameDataをスラッシュで分割して名前リストを取得
String[] nameArrayString = nameData.split("/");
for (int i = 0; i < locArrayString.length; i++) {
// 緯度経度をカンマで分割してLatLngオブジェクトを作成
String[] latLngString = locArrayString[i].split(",");
if (latLngString.length == 2) {
double latitudeDouble = Double.parseDouble(latLngString[0]);
double longitudeDouble = Double.parseDouble(latLngString[1]);
LatLng position = new LatLng(latitudeDouble, longitudeDouble);
latLngList.add(position);
// 名前リストから対応する名前を取得
String nameString = nameArrayString.length > i ? nameArrayString[i] : "Unknown";
nameList.add(nameString);
// 色リストから次の色を取得
int colorInt = getNextColor();
colorList.add(colorInt);
// 地図にピンを追加
addPinToMap(nameString, position, colorInt);
// スクロールビューに場所を追加
addLocationToScrollView(nameString, colorInt);
}
}
// 最初の位置にカメラを移動しルートを描画
if (!latLngList.isEmpty()) {
mMap.moveCamera(CameraUpdateFactory.newLatLngZoom(latLngList.get(0), 17));
drawRoute(); // ルートを描画するメソッドを呼び出す
}
} catch (Exception e) {
Log.e("Maps", "エラーが発生しました。原因は以下", e);
}
}
// ルートを描画するメソッド
// Google マップの Directions API を使用してルート情報を取得しポリラインで描画
private void drawRoute() {
new Thread(() -> {
try {
StringBuilder urlBuilder = new StringBuilder("https://maps.googleapis.com/maps/api/directions/json?");
urlBuilder.append("origin=").append(latLngList.get(0).latitude).append(",").append(latLngList.get(0).longitude);
urlBuilder.append("&destination=").append(latLngList.get(latLngList.size() - 1).latitude).append(",").append(latLngList.get(latLngList.size() - 1).longitude);
if (latLngList.size() > 2) {
urlBuilder.append("&waypoints=");
for (int i = 1; i < latLngList.size() - 1; i++) {
urlBuilder.append("via:").append(latLngList.get(i).latitude).append(",").append(latLngList.get(i).longitude);
if (i < latLngList.size() - 2) {
urlBuilder.append("|");
}
}
}
urlBuilder.append("&mode=driving");
//APiキーの設定
urlBuilder.append("&key=").append("AIzaSyBQ1Ak-I2NL5TP4K59ZI0VgzKk6HNZuusw");
String urlString = urlBuilder.toString();
Log.d("Maps", "Directions API URL: " + urlString);
// Directions APIにリクエストを送信してレスポンスを取得
URL url = new URL(urlString);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
InputStreamReader isr = new InputStreamReader(conn.getInputStream());
BufferedReader br = new BufferedReader(isr);
StringBuilder jsonResults = new StringBuilder();
String lineString;
while ((lineString = br.readLine()) != null) {
jsonResults.append(lineString);
}
br.close();
Log.d("Maps", "API response: " + jsonResults.toString());
// レスポンスからルート情報を取得してポリラインで描画
JsonObject jsonObject = new Gson().fromJson(jsonResults.toString(), JsonObject.class);
JsonArray routes = jsonObject.getAsJsonArray("routes");
if (routes.size() > 0) {
JsonObject route = routes.get(0).getAsJsonObject();
JsonObject polyline = route.getAsJsonObject("overview_polyline");
String encodedString = polyline.get("points").getAsString();
List<LatLng> points = decodePoly(encodedString);
Log.d("Maps", "Polyline points: " + points);
runOnUiThread(() -> mMap.addPolyline(new PolylineOptions().addAll(points).width(5).color(Color.BLUE)));
} else {
// ルートが見つからなかった場合のエラーメッセージを表示
JsonPrimitive errorMessage = jsonObject.getAsJsonPrimitive("error_message");
if (errorMessage != null) {
Log.e("Maps", "エラーが発生しました。原因は以下: " + errorMessage.getAsString());
} else {
Log.e("Maps", "原因不明のエラー");
}
}
} catch (Exception e) {
Log.e("Maps", "ルートの描画に失敗しました", e);
}
}).start();
}
// エンコードされた文字列から座標情報をデコードするためのメソッド
private List<LatLng> decodePoly(String encoded) {
List<LatLng> poly = new ArrayList<>(); // 座標情報を格納するリスト
int index = 0, len = encoded.length();// 文字列のインデックスと長さ
int latInt = 0, lng = 0; // 緯度と経度の初期値
// 文字列の長さに達するまで繰り返す
while (index < len) {
int b, shift = 0, result = 0;
// バイト値を取得しビットシフトとOR演算を行って座標値を復元する
do {
b = encoded.charAt(index++) - 63;
result |= (b & 0x1f) << shift;
shift += 5;
} while (b >= 0x20);
int dlat = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1));
latInt += dlat;
shift = 0;
result = 0;
// バイト値を取得しビットシフトとOR演算を行って座標値を復元する
do {
b = encoded.charAt(index++) - 63;
result |= (b & 0x1f) << shift;
shift += 5;
} while (b >= 0x20);
int dlng = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1));
lng += dlng;
// LatLngオブジェクトを作成してリストに追加する
LatLng p = new LatLng((((double) latInt / 1E5)), (((double) lng / 1E5)));
poly.add(p);
}
// 座標情報のリストを返す
return poly;
}
// Colorクラスを使用して与えられた色から色相値を計算するメソッド
private float getHueFromColor(int color) {
float[] hsv = new float[3];
Color.colorToHSV(color, hsv);//整数の色値をHSV色相彩度明度の形式に変換し色相値を取得します
return hsv[0];
}
//mapにピンを追加するメソッド
private void addPinToMap(String locationName, LatLng position, int color) {
// マーカーオプションを作成し位置タイトル色を設定する
Marker marker = mMap.addMarker(new MarkerOptions().position(position).title(locationName).icon(BitmapDescriptorFactory.defaultMarker(getHueFromColor(color))));
if (marker != null) {
marker.setTag(locationName);
}
}
// スクロールビューに位置情報を追加するメソッド
// スクロールビューに位置情報を追加するメソッド
// スクロールビューに位置情報を追加するメソッド
private void addLocationToScrollView(String locationName, int color) {
runOnUiThread(() -> {
try {
// テキストビューの作成
TextView textView = new TextView(this);
textView.setText(locationName);
textView.setTextSize(20);
textView.setPadding(16, 16, 16, 16);
textView.setTextColor(Color.BLACK); // 文字色を黒に設定
textView.setBackgroundColor(Color.WHITE); // 背景色を白に設定
// 円を作成
ShapeDrawable circle = new ShapeDrawable(new OvalShape());
circle.setIntrinsicWidth(30);
circle.setIntrinsicHeight(30);
circle.getPaint().setColor(color);
// 左側に円を表示するためにDrawableを設定
textView.setCompoundDrawablesWithIntrinsicBounds(circle, null, null, null);
textView.setCompoundDrawablePadding(16);
// テキストビューにクリックリスナーを追加
textView.setOnClickListener(v -> {
for (int j = 0; j < nameList.size(); j++) {
if (nameList.get(j).equals(locationName)) {
mMap.animateCamera(CameraUpdateFactory.newLatLngZoom(latLngList.get(j), 17));
break;
}
}
});
// ボーダーラインの作成
View border = new View(this);
border.setLayoutParams(new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.MATCH_PARENT, // 横幅は親と同じ
2 // 高さは2dp
));
border.setBackgroundColor(Color.GRAY); // ボーダーラインの色を設定
// レイアウトの作成
LinearLayout layout = new LinearLayout(this);
layout.setOrientation(LinearLayout.VERTICAL);
layout.addView(textView);
layout.addView(border);
// スクロールビューにレイアウトを追加
locationsName.addView(layout);
} catch (Exception e) {
Log.e("Maps", "エラーが発生しました。原因は以下", e);
}
});
}
private int getNextColor() {
int color = COLORS[colorIndex];
colorIndex = (colorIndex + 1) % COLORS.length;
return color;
}
@Override
public void onClick(View view) {
if (view.getId() == R.id.BackMain) {
finish();
}
}
@Override
//マーカーがクリックされた際の処理を行うメソッド
public boolean onMarkerClick(Marker marker) {
// マーカーから場所の名前を取得します
String locationName = (String) marker.getTag();
// 場所の名前がnullではない場合に処理を実行します
if (locationName != null) {
// マーカーのタイトルとして場所の名前を設定します
marker.setTitle(locationName);
// マーカーの情報ウィンドウを表示します
marker.showInfoWindow();
}
// デフォルトの動作も実行するためにfalseを返します
return false;
}
}

View File

@ -1,56 +0,0 @@
package com.example.oplogy;
import androidx.fragment.app.FragmentActivity;
import android.os.Bundle;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;
import com.example.oplogy.databinding.ActivityMapsBinding;
public class MapsActivity extends FragmentActivity implements OnMapReadyCallback {
private GoogleMap mMap;
private ActivityMapsBinding binding;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
binding = ActivityMapsBinding.inflate(getLayoutInflater());
setContentView(binding.getRoot());
// Obtain the SupportMapFragment and get notified when the map is ready to be used.
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
.findFragmentById(R.id.map);
mapFragment.getMapAsync(this);
}
/**
* Manipulates the map once available.
* This callback is triggered when the map is ready to be used.
* This is where we can add markers or lines, add listeners or move the camera. In this case,
* we just add a marker near Sydney, Australia.
* If Google Play services is not installed on the device, the user will be prompted to install
* it inside the SupportMapFragment. This method will only be triggered once the user has
* installed Google Play services and returned to the app.
*/
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
// Add a marker in Sydney and move the camera
/// 緯度経度
LatLng loc = new LatLng(35.17260398479137, 136.88635173557998);
/// マーカーオプションを設定情報ウィンドウ
mMap.addMarker(new MarkerOptions().position(loc).title("トライデントコンピュータ専門学校"));
/// 表示位置を地図に指定
mMap.moveCamera(CameraUpdateFactory.newLatLng(loc));
/// 地図の倍率を指定
mMap.moveCamera(CameraUpdateFactory.newLatLngZoom(loc, 17));
}
}

View File

@ -0,0 +1,259 @@
package com.example.oplogy;
import com.google.firebase.Timestamp;
import java.util.List;
public class MyDataClass {
private String patronNameString;
private int classIdInt;
private List<String> addressList;
private List<Timestamp> firstDayList;
private int studentNumberInt;
private String childNameString;
private List<Timestamp> thirdDayList;
private List<Timestamp> secondDayList;
private double latitudeDouble;
private Long timezoneLong;
private String startDateString;
private String endDateString;
private String assignedStartTimeString;
private int assignedIndexInt;
private boolean linkingBoolean;
private String parentStartTimeString;
private String parentEndTimeString;
private int scheduleInt;
private String secondDayStartDateString;
private String secondDayEndDateString;
private Long secondDayTimezoneLong;
private String secondDayParentStartTimeString;
private String secondDayParentEndTimeString;
private String latLngString;
private String ScheduleDayString;
public MyDataClass(String patronName, int classId, List<String> address, List<Timestamp> firstDay, int studentNumber, String childName, List<Timestamp> thirdDay, List<Timestamp> secondDay) {
this.patronNameString = patronName;
this.classIdInt = classId;
this.addressList = address;
this.firstDayList = firstDay;
this.studentNumberInt = studentNumber;
this.childNameString = childName;
this.thirdDayList = thirdDay;
this.secondDayList = secondDay;
}
@Override
public String toString() {
return "MyDataClass{" +
"patronName='" + patronNameString + '\'' +
", classId=" + classIdInt +
", address=" + addressList +
", firstDay=" + firstDayList +
", studentNumber=" + studentNumberInt +
", childName='" + childNameString + '\'' +
", thirdDay=" + thirdDayList +
", secondDay=" + secondDayList +
'}';
}
//getter
public String getPatronName() {
return patronNameString;
}
//setter
public void setPatronName(String patronNameString) {
this.patronNameString = patronNameString;
}
public int getClassId() {
return classIdInt;
}
public void setClassId(int classId) {
this.classIdInt = classId;
}
public List<String> getAddress() {
return addressList;
}
public void setAddress(List<String> address) {
this.addressList = address;
}
public List<Timestamp> getFirstDay() {
return firstDayList;
}
public void setFirstDay(List<Timestamp> firstDay) {
this.firstDayList = firstDay;
}
public int getStudentNumber() {
return studentNumberInt;
}
public void setStudentNumber(int studentNumber) {
this.studentNumberInt = studentNumber;
}
public String getChildName() {
return childNameString;
}
public void setChildName(String childName) {
this.childNameString = childName;
}
public List<Timestamp> getThirdDay() {
return thirdDayList;
}
public void setThirdDay(List<Timestamp> thirdDay) {
this.thirdDayList = thirdDay;
}
public List<Timestamp> getSecondDay() {
return secondDayList;
}
public void setSecondDay(List<Timestamp> secondDay) {
this.secondDayList = secondDay;
}
public double getLatitude() {
return latitudeDouble;
}
public void setLatitude(double latitudeDouble) {
this.latitudeDouble = latitudeDouble;
}
public void setEndDateString(String endDateString) {
this.endDateString = endDateString;
}
public Long getTimezone() {
return timezoneLong;
}
public void setTimezone(Long timezoneLong) {
this.timezoneLong = timezoneLong;
}
public String getStartDateString() {
return startDateString;
}
public void setStartDateString(String startDateString) {
this.startDateString = startDateString;
}
public void setAssignedStartTime(String assignedStartTime) {
this.assignedStartTimeString = assignedStartTime;
}
public String getAssignedEndTime() {
return assignedStartTimeString;
}
public void setAssignedIndex(int assignedIndexInt) {
this.assignedIndexInt = assignedIndexInt;
}
public int getAssignedIndex() {
return assignedIndexInt;
}
public void setLinking(boolean linking) {
this.linkingBoolean = linking;
}
public boolean getLinking() {
return linkingBoolean;
}
public void setParentStartTimeString(String parentStartTimeString) {
this.parentStartTimeString = parentStartTimeString;
}
public void setParentEndTimeString(String parentEndTimeString) {
this.parentEndTimeString = parentEndTimeString;
}
public String getParentStartTimeString() {
return parentStartTimeString;
}
public String getParentEndTimeString() {
return parentEndTimeString;
}
public void setSchedule(int scheduleInt) {
this.scheduleInt = scheduleInt;
}
public int getSchedule() {
return scheduleInt;
}
public void setSecondDayStartDateString(String secondDayStartDateString) {
this.secondDayStartDateString = secondDayStartDateString;
}
public void setSecondDayEndDateString(String secondDayEndDateString) {
this.secondDayEndDateString = secondDayEndDateString;
}
public void setSecondDayTimezone(Long secondDayTimezone) {
this.secondDayTimezoneLong = secondDayTimezone;
}
public Long getSecondDayTimezone() {
return secondDayTimezoneLong;
}
public void setSecondDayParentStartTimeString(String secondDayParentStartTimeString) {
this.secondDayParentStartTimeString = secondDayParentStartTimeString;
}
public void setSecondDayParentEndTimeString(String secondDayParentEndTimeString) {
this.secondDayParentEndTimeString = secondDayParentEndTimeString;
}
public String getSecondDayParentStartTimeString() {
return secondDayParentStartTimeString;
}
public String getSecondDayParentEndTimeString() {
return secondDayParentEndTimeString;
}
public String getSecondDayStartDateString() {
return secondDayStartDateString;
}
public void setLatLngString(String latLng) {
this.latLngString = latLng;
}
public String getLatLngString() {
return latLngString;
}
public void setScheduleDay(String ScheduleDayString) {
this.ScheduleDayString = ScheduleDayString;
}
public String getScheduleDay() {
return ScheduleDayString;
}
}

View File

@ -0,0 +1,320 @@
package com.example.oplogy;
import static android.content.ContentValues.TAG;
import android.annotation.SuppressLint;
import android.app.DatePickerDialog;
import android.app.TimePickerDialog;
import android.content.Intent;
import android.content.SharedPreferences;
import android.graphics.Paint;
import android.os.Bundle;
import android.util.Log;
import android.widget.Button;
import android.widget.DatePicker;
import android.widget.ImageView;
import android.widget.RadioButton;
import android.widget.TextView;
import android.widget.TimePicker;
import android.widget.Toast;
import androidx.fragment.app.DialogFragment;
import androidx.fragment.app.FragmentActivity;
import androidx.room.Room;
import java.util.Locale;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class SetUpActivity extends FragmentActivity
implements TimePickerDialog.OnTimeSetListener, DatePickerDialog.OnDateSetListener {
String teacherNameString;
String startPointString;
String firstDayString;
String secondDayString;
String thirdDayString;
String startTimeString;
String endTimeString;
String intervalTimeString;
String startBreakTimeString;
String endBreakTimeString;
int totalStudentString;
String stringYearString;
String stringMonthString;
String stringDayOfMonthString;
String stringHourOfDayString;
String stringMinuteString;
Button setFirstDay;
Button setSecondDay;
Button setThirdDay;
Button setStartTimeButton;
Button setEndTimeButton;
private TextView setTeacherName;
private TextView setStartPoint;
private TextView setStartTime;
private TextView setEndTime;
private TextView setStartBreakTime;
private TextView setEndBreakTime;
private TextView setTotalStudent;
private int isDateSelectedInt;
private int isStartTimeSelectedInt;
@SuppressLint("MissingInflatedId")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_set_up);
int classIdInt = getIntent().getIntExtra("classId", 100000);
setTeacherName = findViewById(R.id.teacherName); //先生の名前
setStartPoint = findViewById(R.id.startPoint); //開始地点
setFirstDay = findViewById(R.id.setFirstDayButton); //1日目の日付
setSecondDay = findViewById(R.id.setSecondDayButton); //2日目の日付
setThirdDay = findViewById(R.id.setThirdDayButton); //3日目の日付
setStartTimeButton = findViewById(R.id.startTimeSetButton); //開始時刻を設定するボタン
setStartTime = findViewById(R.id.startTime); //開始時刻を出力するTextView
setEndTimeButton = findViewById(R.id.endTimeSetButton); //終了時刻を設定するボタン
setEndTime = findViewById(R.id.endTime); //終了時刻を出力するTextView
RadioButton setTenMinute = findViewById(R.id.tenMinute); //訪問間隔10分
RadioButton setFifteenMinute = findViewById(R.id.fifteenMinute); //訪問間隔15分
RadioButton setThirtyMinute = findViewById(R.id.thirtyMinute); //訪問間隔30分
setStartBreakTime = findViewById(R.id.startBreakTime); //休憩開始時刻
setStartBreakTime.setPaintFlags(Paint.UNDERLINE_TEXT_FLAG);
setEndBreakTime = findViewById(R.id.endBreakTime); //休憩終了時刻
setEndBreakTime.setPaintFlags(Paint.UNDERLINE_TEXT_FLAG);
setTotalStudent = findViewById(R.id.totalStudent); //クラスの人数
ImageView toMain = findViewById(R.id.toMain);
Button setUp = findViewById(R.id.setUpButton); //画面下の設定ボタン
Button reset = findViewById(R.id.resetButton);
toMain.setOnClickListener(view -> {
Intent intent = new Intent(SetUpActivity.this, SettingView.class); //main画面へ戻る処理
startActivity(intent);
});
setUp.setOnClickListener(view -> {
teacherNameString = setTeacherName.getText().toString(); //各変数に値を挿入
startPointString = setStartPoint.getText().toString();
firstDayString = setFirstDay.getText().toString();
secondDayString = setSecondDay.getText().toString();
thirdDayString = setThirdDay.getText().toString();
startTimeString = setStartTime.getText().toString();
endTimeString = setEndTime.getText().toString();
startBreakTimeString = setStartBreakTime.getText().toString();
endBreakTimeString = setEndBreakTime.getText().toString();
try {
totalStudentString = Integer.parseInt(setTotalStudent.getText().toString());
} catch (NumberFormatException e) {
Toast.makeText(SetUpActivity.this, "記入欄にすべて入力を済ませてから押してください", Toast.LENGTH_SHORT).show();
return;
}
Log.d(TAG, "Teacher Name: " + teacherNameString);
Log.d(TAG, "Start Point: " + startPointString);
Log.d(TAG, "First Day:" + firstDayString);
Log.d(TAG, "Second Day:" + secondDayString);
Log.d(TAG, "Third Day:" + thirdDayString);
Log.d(TAG, "Start Time" + startTimeString);
Log.d(TAG, "End Time" + endTimeString);
if (setTenMinute.isChecked()) { //ラジオボタンの状態を取得
intervalTimeString = "10";
} else if (setFifteenMinute.isChecked()) {
intervalTimeString = "15";
} else if (setThirtyMinute.isChecked()) {
intervalTimeString = "30";
} else {
intervalTimeString = "0";
}
Log.d(TAG, "Interval Time" + intervalTimeString);
Log.d(TAG, "Start Break Time" + startBreakTimeString);
Log.d(TAG, "End Break Time" + endBreakTimeString);
Log.d(TAG, "Total Student" + totalStudentString);
Log.d(TAG, "onClick: できてるよ");
// データベースへの登録処理
ExecutorService executor = Executors.newSingleThreadExecutor();
executor.execute(() -> {
//roomのインスタンスを作成
AppDatabase db = Room.databaseBuilder(getApplicationContext(), AppDatabase.class, "SetUpTable")
.fallbackToDestructiveMigration()
.build();
SetUpTableDao setUpTableDao = db.setUpTableDao();
// Roomの操作を行う
SetUpTable setUpTable = new SetUpTable(
teacherNameString,
startPointString,
startTimeString,
endTimeString,
intervalTimeString,
startBreakTimeString,
endBreakTimeString,
totalStudentString,
classIdInt
);
// 同じ名前のエントリが存在するかどうかを確認
SetUpTable existingSetUpTable = setUpTableDao.findByName(teacherNameString);
if (existingSetUpTable != null) {
// エントリが存在する場合はそのエントリを更新
setUpTable.setId(existingSetUpTable.getId()); // 既存のIDを設定
setUpTableDao.update(setUpTable);
runOnUiThread(() -> Toast.makeText(SetUpActivity.this, "更新しました", Toast.LENGTH_SHORT).show());
} else {
// エントリが存在しない場合は新しいエントリを挿入
setUpTableDao.insertAll(setUpTable);
runOnUiThread(() -> Toast.makeText(SetUpActivity.this, "登録しました", Toast.LENGTH_SHORT).show());
}
//家庭訪問日を保存する共有プリファレンス
SharedPreferences sharedPreferences = getSharedPreferences("visitingDate", MODE_PRIVATE);
SharedPreferences.Editor editor = sharedPreferences.edit();
editor.putString("day1", firstDayString);
editor.putString("day2", secondDayString);
editor.putString("day3", thirdDayString);
editor.apply();
});
});
setFirstDay.setOnClickListener(v -> {
isDateSelectedInt = 1;
showDatePickerDialog(); //DatePickerの表示
});
setSecondDay.setOnClickListener(v -> {
isDateSelectedInt = 2;
showDatePickerDialog();
});
setThirdDay.setOnClickListener(v -> {
isDateSelectedInt = 3;
showDatePickerDialog();
});
setStartTimeButton.setOnClickListener(v -> {
isStartTimeSelectedInt = 1; //ボタンの判別
showTimePickerDialog(); //TimePickerの表示
});
setEndTimeButton.setOnClickListener(v -> {
isStartTimeSelectedInt = 2;
showTimePickerDialog();
});
setStartBreakTime.setOnClickListener(v -> {
isStartTimeSelectedInt = 3;
showTimePickerDialog();
});
setEndBreakTime.setOnClickListener(v -> {
isStartTimeSelectedInt = 4;
showTimePickerDialog();
});
//リセットボタンの処理
reset.setOnClickListener(v -> { //テキストとラジオボタンの選択を消去
setTeacherName.setText("");
setStartPoint.setText("");
setTenMinute.setChecked(false);
setFifteenMinute.setChecked(false);
setThirtyMinute.setChecked(false);
setStartBreakTime.setText("");
setEndBreakTime.setText("");
setTotalStudent.setText("");
ExecutorService executor = Executors.newSingleThreadExecutor();
executor.execute(() -> {
AppDatabase db = Room.databaseBuilder(getApplicationContext(), AppDatabase.class, "SetUpTable").build();
SetUpTableDao setUpTableDao = db.setUpTableDao();
setUpTableDao.deleteAll();
});
});
}
@Override
public void onDateSet(DatePicker datePicker, int year, int month, int dayOfMonth) { //Dateを成形する
// DatePickerDialogで選択された日付を処理する
String str = String.format(Locale.JAPAN, "%02d/%02d", month + 1, dayOfMonth); // TextViewに表示する日付の形式を設定
if (isDateSelectedInt == 1) {
stringYearString = String.valueOf(year); //
stringMonthString = String.format(Locale.JAPAN, "%02d", month + 1); //
stringDayOfMonthString = String.format(Locale.JAPAN, "%02d", dayOfMonth); //
firstDayString = stringYearString + stringMonthString + stringDayOfMonthString;
setFirstDay.setText(str);
} else if (isDateSelectedInt == 2) {
stringYearString = String.valueOf(year);
stringMonthString = String.format(Locale.JAPAN, "%02d", month + 1);
stringDayOfMonthString = String.format(Locale.JAPAN, "%02d", dayOfMonth);
secondDayString = stringYearString + stringMonthString + stringDayOfMonthString;
setSecondDay.setText(str);
} else if (isDateSelectedInt == 3) {
stringYearString = String.valueOf(year);
stringMonthString = String.format(Locale.JAPAN, "%02d", month + 1);
stringDayOfMonthString = String.format(Locale.JAPAN, "%02d", dayOfMonth);
thirdDayString = stringYearString + stringMonthString + stringDayOfMonthString;
setThirdDay.setText(str);
}
}
@SuppressLint({"DefaultLocale", "SetTextI18n"})
@Override
public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
String str = String.format(Locale.JAPAN, "%02d:%02d", hourOfDay, minute); // Textviewに保存する形式を設定
if (isStartTimeSelectedInt == 1) {
stringHourOfDayString = String.format("%02d", hourOfDay);
stringMinuteString = String.format("%02d", minute);
startTimeString = stringHourOfDayString + stringMinuteString;
setStartTime.setText(str);
} else if (isStartTimeSelectedInt == 2) {
stringHourOfDayString = String.format("%02d", hourOfDay);
stringMinuteString = String.format("%02d", minute);
endTimeString = stringHourOfDayString + stringMinuteString;
setEndTime.setText(str);
} else if (isStartTimeSelectedInt == 3) {
stringHourOfDayString = String.format("%02d", hourOfDay);
stringMinuteString = String.format("%02d", minute);
startBreakTimeString = stringHourOfDayString + stringMinuteString;
setStartBreakTime.setText(" " + str + " ");
} else if (isStartTimeSelectedInt == 4) {
stringHourOfDayString = String.format("%02d", hourOfDay);
stringMinuteString = String.format("%02d", minute);
endBreakTimeString = stringHourOfDayString + stringMinuteString;
setEndBreakTime.setText(" " + str + " ");
}
}
private void showDatePickerDialog() {
DialogFragment newFragment = new DatePick();
newFragment.show(getSupportFragmentManager(), "datePicker");
}
private void showTimePickerDialog() { // Dialogを表示する
DialogFragment newFragment = new TimePick();
newFragment.show(getSupportFragmentManager(), "timePicker");
}
}

View File

@ -0,0 +1,73 @@
package com.example.oplogy;
import androidx.room.Entity;
import androidx.room.PrimaryKey;
@Entity
public class SetUpTable {
//主キー
@PrimaryKey(autoGenerate = true)
public int id;
public String teacherName;
public String startPoint;
public String startTime;
public String endTime;
public String intervalTime;
public String startBreakTime;
public String endBreakTime;
public int totalStudent;
int classId;
//コンストラクタ
public SetUpTable(String teacherName, String startPoint, String startTime, String endTime,
String intervalTime, String startBreakTime, String endBreakTime, int totalStudent,int classId) {
this.teacherName = teacherName;
this.startPoint = startPoint;
this.startTime = startTime;
this.endTime = endTime;
this.intervalTime = intervalTime;
this.startBreakTime = startBreakTime;
this.endBreakTime = endBreakTime;
this.totalStudent = totalStudent;
this.classId = classId;
}
//getter
public int getId() {
return id;
}
public String getTeacherName() {
return teacherName;
}
public String getStartPoint() {
return startPoint;
}
public String getStartTime() {
return startTime;
}
public String getEndTime() {
return endTime;
}
public int getTotalStudent() {
return totalStudent;
}
//setter
public void setId(int id) {
this.id = id;
}
public void setTeacherName(String teacherName) {
this.teacherName = teacherName;
}
public void setStartPoint(String startPoint) {
this.startPoint = startPoint;
}
public void setStartTime(String startTime) {
this.startTime = startTime;
}
public void setEndTime(String endTime) {
this.endTime = endTime;
}
public void setTotalStudent(int totalStudent) {
this.totalStudent = totalStudent;
}
}

View File

@ -0,0 +1,52 @@
package com.example.oplogy;
import androidx.room.Dao;
import androidx.room.Insert;
import androidx.room.Query;
import androidx.room.Update;
import java.util.List;
@Dao
public interface SetUpTableDao {
@Insert
void insertAll(SetUpTable... setUpTables);
//更新処理
@Update
void update(SetUpTable setUpTable);
//名前が一致しているかの確認
//削除処理
@Query("DELETE FROM SetUpTable")
void deleteAll();
//全件取得
@Query("SELECT * FROM SetUpTable")
List<SetUpTable> getAll();
@Query("SELECT * FROM SetUpTable WHERE teacherName = :name LIMIT 1")
SetUpTable findByName(String name);
@Query("SELECT totalStudent FROM SetUpTable")
int getTotalStudent();
//開始時間と終了時間の取得
@Query("SELECT startTime FROM SetUpTable")
String getStartTime();
@Query("SELECT endTime FROM SetUpTable")
String getEndTime();
//教師名の取得
@Query("SELECT teacherName FROM SetUpTable")
String getTeacherName();
@Query("SELECT intervalTime FROM SetUpTable")
String getIntervalTime();
@Query("SELECT StartBreakTime FROM SetUpTable")
String getStartBreakTime();
@Query("SELECT EndBreakTime FROM SetUpTable")
String getEndBreakTime();
//クラスIDの取得
@Query("SELECT classId FROM SetUpTable")
int getClassId();
@Query("SELECT startPoint FROM setuptable")
String getStartPoint();
}

View File

@ -0,0 +1,190 @@
package com.example.oplogy;
import android.content.ClipData;
import android.content.ClipboardManager;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;
import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;
import androidx.room.Room;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class SettingView extends AppCompatActivity implements View.OnClickListener {
// formコピー用のURL
private static final String URL_TO_COPY = "https://docs.google.com/forms/d/e/1FAIpQLScKI_ca01nO7die7SqZyThiqa7NB7gcucMJtiV_-sc3eZX6KQ/viewform";
private View backButton;
private View creatUUID;
private View imageUuid;
private View setUp;
private View imageSetup;
private View formURL;
private View imageFormURL;
private AlertDialog alertDialog;
private int classId;
private FirestoreReception_classIdDatabase firestoreReception_classIdDatabase;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_setting_view);
// 戻るボタンの処理
backButton = findViewById(R.id.BackMain_fromSetting);
backButton.setOnClickListener(this);
// ID作成用のインテント
creatUUID = findViewById(R.id.creatUUID);
creatUUID.setOnClickListener(this);
imageUuid = findViewById(R.id.imageUuid);
imageUuid.setOnClickListener(this);
// セットアップ用のインテント
setUp = findViewById(R.id.setUp);
setUp.setOnClickListener(this);
imageSetup = findViewById(R.id.imageSetup);
imageSetup.setOnClickListener(this);
// formコピー用のインテント
formURL = findViewById(R.id.formURL);
formURL.setOnClickListener(this);
imageFormURL = findViewById(R.id.imageFormURL);
imageFormURL.setOnClickListener(this);
}
@Override
public void onClick(View view) {
if (view == backButton) {
Intent intent = new Intent(SettingView.this, MainActivity.class);
startActivity(intent);
}
// ID作成のクリック処理
if (view == creatUUID) {
showUUIDYesNoDialog();//UUIDを表示するかのダイアログ
}
if (view == imageUuid) {
showUUIDYesNoDialog();//UUIDを表示するかのダイアログ
}
// セットアップのクリック処理
if (view == setUp) {
Intent toSetup = new Intent(SettingView.this, SetUpActivity.class);
toSetup.putExtra("classId", classId);
startActivity(toSetup);
}
if (view == imageSetup) {
Intent toSetup = new Intent(SettingView.this, SetUpActivity.class);
startActivity(toSetup);
}
// formコピー用のクリック処理
if (view == formURL) {
copyUrlToClipboard(URL_TO_COPY);
}
if (view == imageFormURL) {
copyUrlToClipboard(URL_TO_COPY);
}
}
//ID作成表示に関する処理
private void showUUIDYesNoDialog() {
firestoreReception_classIdDatabase = new FirestoreReception_classIdDatabase();
List<Integer> classIdList = firestoreReception_classIdDatabase.getAllDocumentsFromClassIdDatabase();
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setTitle("ID");
builder.setMessage("あなたのIDを表示/もしくは新規で作成しますか?");
//作成処理
builder.setPositiveButton("作成", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
classId = CreateUUID.generateUUID(classIdList);
// 生成されたIDを表示するメソッド
showClassIdDialog("生成されたID", classId);
}
});
//表示処理
builder.setNegativeButton("表示", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
//roomを扱うため非同期処理
ExecutorService executor = Executors.newSingleThreadExecutor();
executor.execute(() -> {
// 現在のクラスIDを取得
int currentClassId = getCurrentClassIdFromRoom();
if (currentClassId == 0) {
currentClassId = classId;
}
final int showDialogClassId = currentClassId;
runOnUiThread(() -> {
// 現在のクラスIDを表示するダイアログ
showClassIdDialog("現在のID", showDialogClassId);
});
});
executor.shutdown();
}
});
alertDialog = builder.create();
alertDialog.show();
}
//Roomから現在のクラスIDを取得するメソッド
private int getCurrentClassIdFromRoom() {
AppDatabase db = getDatabaseInstance();
SetUpTableDao setUpTableDao = db.setUpTableDao();
// 現在のクラスIDを取得
return setUpTableDao.getClassId();
}
//クラスIDを表示するダイアログ
private void showClassIdDialog(String title, int classId) {
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setTitle(title);
builder.setMessage("ID: " + classId);
builder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
});
AlertDialog dialog = builder.create();
dialog.show();
}
//クリップボードにURLをコピーする処理
private void copyUrlToClipboard(String url) {
try {
ClipboardManager clipboard = (ClipboardManager) getSystemService(Context.CLIPBOARD_SERVICE);
ClipData clip = ClipData.newPlainText("URL", url);
if (clipboard != null) {
clipboard.setPrimaryClip(clip);
Toast.makeText(this, "GoogleFormのURLをコピーしました", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(this, "エラー コピーできませんでした", Toast.LENGTH_SHORT).show();
}
} catch (Exception e) {
Toast.makeText(this, "Error copying URL: " + e.getMessage(), Toast.LENGTH_SHORT).show();
}
}
// データベースのインスタンスを取得するメソッド
private AppDatabase getDatabaseInstance() {
return Room.databaseBuilder(getApplicationContext(), AppDatabase.class, "SetUpTable").build();
}
}

View File

@ -0,0 +1,55 @@
package com.example.oplogy;
import android.os.Bundle;
import android.util.Log;
import android.widget.ImageView;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import java.util.ArrayList;
import java.util.List;
public class SubmissionActivity extends AppCompatActivity {
private final List<SubmissionStudent> studentsList = new ArrayList<>();
private RecyclerView recyclerView;
private SubmissionAdapter submissionAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.submission);
// 戻るボタンの処理
ImageView backButton = findViewById(R.id.BackMain_fromSubmission);
backButton.setOnClickListener(v -> finish());
// RecyclerViewとアダプターの初期化
recyclerView = findViewById(R.id.recyclerView);
recyclerView.setLayoutManager(new LinearLayoutManager(this));
submissionAdapter = new SubmissionAdapter(studentsList);
recyclerView.setAdapter(submissionAdapter);
// 生徒のリストを取得
fetchStudents();
}
private void fetchStudents() {
// インテントから生徒のリストを取得
ArrayList<SubmissionStudent> submissionStudentsList = getIntent().getParcelableArrayListExtra("submissionStudents");
if (submissionStudentsList != null) {
Log.d("SubmissionActivity", "Size of submissionStudentsList: " + submissionStudentsList.size());
studentsList.addAll(submissionStudentsList);
} else {
Log.e("SubmissionActivity", "submissionStudentsList is null");
Toast.makeText(this, "生徒のリストが取得できませんでした", Toast.LENGTH_SHORT).show();
}
// データが変更されたことをアダプターに通知
submissionAdapter.notifyDataSetChanged();
}
}

View File

@ -0,0 +1,72 @@
package com.example.oplogy;
import android.graphics.Color;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
import java.util.List;
public class SubmissionAdapter extends RecyclerView.Adapter<SubmissionAdapter.StudentViewHolder> {
private final List<SubmissionStudent> studentsList;
public SubmissionAdapter(List<SubmissionStudent> students) {
this.studentsList = students;
}
@NonNull
@Override
public StudentViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.row_submission, parent, false);
return new StudentViewHolder(view);
}
@Override
public void onBindViewHolder(StudentViewHolder holder, int position) {
SubmissionStudent student = studentsList.get(position);
holder.studentNumberTextView.setText(String.valueOf(student.getStudentNumber()));
updateStatus(holder, student.isSubmitted());
}
@Override
public int getItemCount() {
return studentsList.size();
}
//真偽値に応じて提出済みか未提出をセットする
private void updateStatus(StudentViewHolder holder, boolean isSubmitted) {
if (isSubmitted) {
holder.statusTextView.setText("提出済み");
setColors(holder, Color.BLACK, Color.WHITE);
} else {
holder.statusTextView.setText("未提出");
setColors(holder, Color.RED, Color.WHITE);
}
}
//真偽値に応じて色をセットする
private void setColors(StudentViewHolder holder, int backgroundColor, int textColor) {
holder.statusTextView.setBackgroundColor(backgroundColor);
holder.statusTextView.setTextColor(textColor);
holder.studentNumberTextView.setBackgroundColor(backgroundColor);
holder.studentNumberTextView.setTextColor(textColor);
}
public static class StudentViewHolder extends RecyclerView.ViewHolder {
public TextView studentNumberTextView;
public TextView statusTextView;
public StudentViewHolder(View view) {
super(view);
// レイアウトファイルのTextViewを取得
studentNumberTextView = view.findViewById(R.id.studentNumberTextView);
statusTextView = view.findViewById(R.id.statusTextView);
}
}
}

View File

@ -0,0 +1,49 @@
package com.example.oplogy;
import android.os.Parcel;
import android.os.Parcelable;
public class SubmissionStudent implements Parcelable {
private int studentNumberInt;
private boolean submitted;
public SubmissionStudent(int studentNumber, boolean submitted) {
this.studentNumberInt = studentNumber;
this.submitted = submitted;
}
protected SubmissionStudent(Parcel in) {
studentNumberInt = in.readInt();
submitted = in.readByte() != 0;
}
public static final Creator<SubmissionStudent> CREATOR = new Creator<SubmissionStudent>() {
@Override
public SubmissionStudent createFromParcel(Parcel in) {
return new SubmissionStudent(in);
}
@Override
public SubmissionStudent[] newArray(int size) {
return new SubmissionStudent[size];
}
};
public int getStudentNumber() {
return studentNumberInt;
}
public boolean isSubmitted() {
return submitted;
}
@Override
public int describeContents() {
return 0;
}
@Override
public void writeToParcel(Parcel parcel, int i) {
parcel.writeInt(studentNumberInt);
parcel.writeByte((byte) (submitted ? 1 : 0));
}
}

View File

@ -0,0 +1,30 @@
package com.example.oplogy;
import android.app.Dialog;
import android.app.TimePickerDialog;
import android.os.Bundle;
import android.widget.TimePicker;
import androidx.annotation.NonNull;
import androidx.fragment.app.DialogFragment;
import java.util.Calendar;
public class TimePick extends DialogFragment implements
TimePickerDialog.OnTimeSetListener{
@NonNull
@Override
public Dialog onCreateDialog(Bundle savedInstanceState) { // TimePeckerの生成
final Calendar c = Calendar.getInstance();
int hourInt = c.get(Calendar.HOUR_OF_DAY);
int minuteInt = c.get(Calendar.MINUTE);
return new TimePickerDialog(getActivity(),
(TimePickerDialog.OnTimeSetListener) getActivity(), hourInt, minuteInt, true);
}
@Override
public void onTimeSet(TimePicker view, int hourOfDayInt, int minuteInt) {
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 48 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 46 KiB

View File

@ -1,69 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:orientation="vertical">
<EditText
android:id="@+id/editNumber"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="番号" />
<EditText
android:id="@+id/editAddress"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="住所" />
<EditText
android:id="@+id/editDate"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="日付" />
<EditText
android:id="@+id/editTime"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="時間" />
<Button
android:id="@+id/btnAdd"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="追加"/>
<Button
android:id="@+id/btnShow"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="表示" />
<TextView
android:id="@+id/showText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="" />
=======
<Button
android:id="@+id/mapmapcreate"
android:text="マップ生成"
android:textSize="50px"
android:layout_width="match_parent"
android:layout_height="wrap_content"
/>
<EditText
android:id="@+id/textview1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="100px"
android:hint="ここだよ"
android:text=""
/>
</LinearLayout>

View File

@ -1,9 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:map="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/map"
android:name="com.google.android.gms.maps.SupportMapFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MapsActivity" />

View File

@ -0,0 +1,358 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".SetUpActivity"
android:orientation="vertical"
android:gravity="center">
<!-- <TextView-->
<!-- android:id="@+id/backMain"-->
<!-- android:layout_width="wrap_content"-->
<!-- android:layout_height="wrap_content"-->
<!-- android:layout_gravity="left"-->
<!-- android:paddingStart="20dp"-->
<!-- android:text="@string/Back"-->
<!-- android:textSize="50sp"-->
<!-- tools:ignore="RtlCompat,RtlHardcoded,RtlSymmetry" />-->
<ImageView
android:id="@+id/toMain"
android:layout_width="60dp"
android:layout_height="60dp"
android:layout_gravity="left"
android:layout_marginLeft="10dp"
android:src="@drawable/back_button"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/setUp"
android:textSize="30sp"/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp"
android:gravity="center">
<TextView
android:layout_width="90sp"
android:layout_height="wrap_content"
android:text="@string/teacherName"
android:gravity="center"/>
<EditText
android:id="@+id/teacherName"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:autofillHints=""
android:inputType=""
tools:ignore="LabelFor" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp"
android:gravity="center">
<TextView
android:layout_width="90sp"
android:layout_height="wrap_content"
android:text="@string/startPoint"
android:gravity="center"/>
<EditText
android:id="@+id/startPoint"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="@string/startpoint"
android:autofillHints=""
android:inputType=""
tools:ignore="LabelFor" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp"
android:gravity="center">
<TextView
android:layout_width="90sp"
android:layout_height="wrap_content"
android:text="日付設定"
android:gravity="center"/>
<!-- <TextView-->
<!-- android:id="@+id/startTime"-->
<!-- android:layout_width="wrap_content"-->
<!-- android:layout_height="wrap_content"-->
<!-- android:text="   "-->
<!-- android:textSize="20sp"-->
<!-- android:textAlignment="center"-->
<!-- android:autofillHints=""-->
<!-- android:inputType=""-->
<!-- tools:ignore="HardcodedText,LabelFor"/>-->
<Button
android:id="@+id/setFirstDayButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="1日目"
android:layout_marginStart="7sp"
android:layout_marginEnd="7sp"
tools:ignore="DuplicateIds" />
<Button
android:id="@+id/setSecondDayButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="2日目"
android:layout_marginStart="7sp"
android:layout_marginEnd="7sp"
tools:ignore="DuplicateIds" />
<Button
android:id="@+id/setThirdDayButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="3日目"
android:layout_marginStart="7sp"
android:layout_marginEnd="7sp"
tools:ignore="DuplicateIds" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp"
android:gravity="center">
<TextView
android:layout_width="90sp"
android:layout_height="wrap_content"
android:text="@string/startTime"
android:gravity="center"/>
<TextView
android:id="@+id/startTime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:hint="未設定"
android:textSize="20sp"
android:textAlignment="center"
android:autofillHints=""
android:inputType=""
tools:ignore="LabelFor"/>
<Button
android:id="@+id/startTimeSetButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/timeSet"
android:layout_marginStart="65dp"
android:layout_marginEnd="65dp"
tools:ignore="DuplicateIds" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp"
android:gravity="center">
<TextView
android:layout_width="90sp"
android:layout_height="wrap_content"
android:text="@string/endTime"
android:gravity="center"/>
<TextView
android:id="@+id/endTime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:hint="未設定"
android:textSize="20sp"
android:textAlignment="center"
android:autofillHints=""
android:inputType=""
tools:ignore="LabelFor"/>
<Button
android:id="@+id/endTimeSetButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/timeSet"
android:layout_marginStart="65dp"
android:layout_marginEnd="65dp"
tools:ignore="DuplicateIds" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp"
android:gravity="center">
<TextView
android:layout_width="90sp"
android:layout_height="wrap_content"
android:text="@string/intervalTime"
android:gravity="center"/>
<RadioGroup
android:id="@+id/timeInterval"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:weightSum="3">
<RadioButton
android:id="@+id/tenMinute"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="@string/tenMinute"
android:paddingEnd="20dp"
tools:ignore="RtlSymmetry" />
<RadioButton
android:id="@+id/fifteenMinute"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="@string/fifteenMinute"
android:paddingEnd="20dp"
tools:ignore="RtlSymmetry" />
<RadioButton
android:id="@+id/thirtyMinute"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="@string/thirtyMinute"
android:paddingEnd="20dp"
tools:ignore="RtlSymmetry" />
</RadioGroup>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="5dp"
android:orientation="horizontal"
android:weightSum="10"
android:gravity="center">
<TextView
android:layout_width="90sp"
android:layout_height="wrap_content"
android:gravity="center"
android:layout_weight="1"
android:text="@string/breakTime" />
<TextView
android:id="@+id/startBreakTime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:hint=" から "
android:textSize="20sp"
android:textAlignment="center"
android:autofillHints=""
android:layout_weight="4"
android:inputType=""
tools:ignore="LabelFor"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text=""
android:textSize="30sp"
android:paddingStart="30dp"
android:paddingEnd="30dp" />
<TextView
android:id="@+id/endBreakTime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="20sp"
android:hint=" まで "
android:textAlignment="center"
android:autofillHints=""
android:layout_weight="4"
android:inputType=""
tools:ignore="LabelFor"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp"
android:gravity="center">
<TextView
android:layout_width="90sp"
android:layout_height="wrap_content"
android:text="@string/totalStudent"
android:gravity="center"/>
<EditText
android:id="@+id/totalStudent"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="例30人➝30"
android:autofillHints=""
android:inputType=""
tools:ignore="LabelFor"/>
</LinearLayout>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:weightSum="2"
android:layout_marginTop="20sp">
<Button
android:id="@+id/resetButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/reset"
android:layout_marginEnd="100dp"
style="?android:attr/buttonBarButtonStyle" />
<Button
android:id="@+id/setUpButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/setUp"
style="?android:attr/buttonBarButtonStyle" />
</LinearLayout>
</LinearLayout>

View File

@ -0,0 +1,126 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:weightSum="13"
tools:context=".SettingView">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="2"
android:gravity="center"
android:orientation="horizontal"
android:weightSum="10">
<ImageView
android:id="@+id/BackMain_fromSetting"
android:layout_width="36dp"
android:layout_height="74dp"
android:layout_weight="3"
android:src="@drawable/back_button" />
<TextView
android:id="@+id/Setting"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="7"
android:padding="8dp"
android:text="設定"
android:textSize="40dp" />
</LinearLayout>
<!-- ID作成のレイアウト-->
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="0dp"
android:layout_gravity="center"
android:layout_weight="3"
android:orientation="horizontal"
android:weightSum="2">
<ImageView
android:id="@+id/imageUuid"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:padding="16dp"
android:src="@drawable/createid" />
<TextView
android:id="@+id/creatUUID"
android:layout_width="99dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1"
android:gravity="left"
android:text="ID作成"
android:textSize="50dp" />
</LinearLayout>
<!-- セットアップのレイアウト-->
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="0dp"
android:layout_gravity="center"
android:layout_weight="3"
android:orientation="horizontal"
android:weightSum="2">
<ImageView
android:id="@+id/imageSetup"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:padding="16dp"
android:src="@drawable/settingsetup" />
<TextView
android:id="@+id/setUp"
android:layout_width="99dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1"
android:gravity="left"
android:text="家庭訪問情報"
android:textSize="36dp"
android:textStyle="bold" />
</LinearLayout>
<!-- フォームのURLのレイアウト-->
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="0dp"
android:layout_gravity="center"
android:layout_weight="3"
android:orientation="horizontal"
android:weightSum="2">
<ImageView
android:id="@+id/imageFormURL"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:padding="16dp"
android:src="@drawable/form" />
<TextView
android:id="@+id/formURL"
android:layout_width="99dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1"
android:gravity="left"
android:text="GoogleformのURL"
android:textSize="28dp"
android:textStyle="bold" />
</LinearLayout>
</LinearLayout>

View File

@ -0,0 +1,9 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".CreateUUID">
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,10 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".DialogFragment">
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,148 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:weightSum="20"
tools:context=".MainActivity">
<Space
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="2" />
<!-- タイトルのレイアウト-->
<LinearLayout
android:layout_width="400dp"
android:layout_height="0dp"
android:layout_gravity="center"
android:layout_weight="4"
android:orientation="horizontal"
android:weightSum="3">
<ImageView
android:id="@+id/imageTitle"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:src="@drawable/app_icon" />
<TextView
android:id="@+id/title"
android:layout_width="99dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="2"
android:gravity="left"
android:text="OPLOGY"
android:textSize="60dp"
android:textStyle="bold" />
</LinearLayout>
<Space
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="2" />
<!-- ルート表示のレイアウト-->
<LinearLayout
android:layout_width="400dp"
android:layout_height="0dp"
android:layout_gravity="center"
android:layout_weight="3"
android:orientation="horizontal"
android:weightSum="2">
<ImageView
android:id="@+id/imageRoot"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:src="@drawable/pin" />
<TextView
android:id="@+id/root"
android:layout_width="99dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1"
android:gravity="left"
android:text="ルート表示"
android:textSize="40dp"
android:textStyle="bold" />
</LinearLayout>
<Space
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0.5" />
<!-- 提出状況のレイアウト-->
<LinearLayout
android:layout_width="350dp"
android:layout_height="0dp"
android:layout_gravity="center"
android:layout_weight="3"
android:orientation="horizontal"
android:weightSum="2">
<ImageView
android:id="@+id/imageSubmission"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:src="@drawable/submission" />
<TextView
android:id="@+id/submission"
android:layout_width="99dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1"
android:gravity="left"
android:text="提出状況"
android:textSize="40dp"
android:textStyle="bold" />
</LinearLayout>
<Space
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0.5" />
<!-- 諸々の設定のレイアウト-->
<LinearLayout
android:layout_width="350dp"
android:layout_height="0dp"
android:layout_gravity="center"
android:layout_weight="3"
android:orientation="horizontal"
android:weightSum="2">
<ImageView
android:id="@+id/imageSetting"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:src="@drawable/setting" />
<TextView
android:id="@+id/setting"
android:layout_width="99dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1"
android:gravity="left"
android:text="設定"
android:textSize="40dp"
android:textStyle="bold" />
</LinearLayout>
</LinearLayout>

View File

@ -0,0 +1,58 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:weightSum="10"
android:orientation="vertical"
tools:context=".Maps">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="center"
android:orientation="horizontal"
android:weightSum="10">
<ImageView
android:id="@+id/BackMain"
android:layout_width="40dp"
android:layout_height="90dp"
android:src="@drawable/back_button"
android:layout_weight="3" />
<Spinner
android:id="@+id/date"
android:layout_width="wrap_content"
android:layout_height="90dp"
android:layout_weight="7" />
</LinearLayout>
<fragment
android:id="@+id/map"
android:name="com.google.android.gms.maps.SupportMapFragment"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="6"
tools:context=".Maps" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="3"
android:gravity="center"
android:orientation="horizontal"
>
<ScrollView
android:id="@+id/scrollable"
android:layout_width="match_parent"
android:layout_height="300dp"
>
<LinearLayout
android:id="@+id/locationsName"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" />
</ScrollView>
</LinearLayout>
</LinearLayout>

View File

@ -0,0 +1,30 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView
android:id="@+id/studentNumberTextView"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:background="@android:color/white"
android:gravity="center_vertical"
android:text="番号"
android:textColor="@android:color/black"
android:textSize="36sp"
android:textStyle="bold" />
<TextView
android:id="@+id/statusTextView"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="3"
android:background="@android:color/white"
android:gravity="center_vertical"
android:paddingStart="8dp"
android:text="提出状況"
android:textColor="@android:color/black"
android:textSize="36sp" />
</LinearLayout>

View File

@ -0,0 +1,42 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:weightSum="10"
tools:context=".SubmissionActivity">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:gravity="center"
android:orientation="horizontal"
android:weightSum="10">
<ImageView
android:id="@+id/BackMain_fromSubmission"
android:layout_width="36dp"
android:layout_height="74dp"
android:layout_weight="2"
android:src="@drawable/back_button" />
<TextView
android:id="@+id/imageSubmission"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="4"
android:hint="提出状況"
android:padding="8dp"
android:textSize="40dp" />
</LinearLayout>
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="9"
android:scrollbars="vertical" />
</LinearLayout>

View File

@ -1,6 +1,5 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> <adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" /> <background android:drawable="@color/ic_launcher_background"/>
<foreground android:drawable="@drawable/ic_launcher_foreground" /> <foreground android:drawable="@mipmap/ic_launcher_foreground"/>
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon> </adaptive-icon>

View File

@ -1,6 +1,5 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> <adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" /> <background android:drawable="@color/ic_launcher_background"/>
<foreground android:drawable="@drawable/ic_launcher_foreground" /> <foreground android:drawable="@mipmap/ic_launcher_foreground"/>
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon> </adaptive-icon>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 5.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.8 KiB

After

Width:  |  Height:  |  Size: 7.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 982 B

After

Width:  |  Height:  |  Size: 3.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 4.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.9 KiB

After

Width:  |  Height:  |  Size: 8.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 23 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.8 KiB

After

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.8 KiB

After

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 45 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.8 KiB

After

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.8 KiB

After

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 75 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.6 KiB

After

Width:  |  Height:  |  Size: 34 KiB

View File

@ -0,0 +1,4 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="ic_launcher_background">#FFFFFF</color>
</resources>

View File

@ -1,4 +1,19 @@
<resources> <resources>
<string name="app_name">oplogy</string> <string name="app_name">Oplogy</string>
<string name="maps_api_key">AIzaSyBqLqPm76UFpwbpU8b3oiH0wbkhosrPWpU</string>
<string name="title_activity_maps">MapsActivity</string> <string name="title_activity_maps">MapsActivity</string>
<string name="setUp">設定</string>
<string name="reset">データ削除</string>
<string name="teacherName">担任の名前</string>
<string name="startPoint">開始地点</string>
<string name="startTime">開始時刻</string>
<string name="endTime">終了時刻</string>
<string name="intervalTime">訪問間隔</string>
<string name="breakTime">休憩時間</string>
<string name="totalStudent">生徒の人数</string>
<string name="timeSet">時刻設定</string>
<string name="startpoint">住所</string>
<string name="tenMinute">10分</string>
<string name="fifteenMinute">15分</string>
<string name="thirtyMinute">30分</string>
</resources> </resources>

View File

@ -1,10 +1,11 @@
buildscript { buildscript {
dependencies { dependencies {
classpath 'com.google.gms:google-services:4.3.14' classpath 'com.google.gms:google-services:4.3.14'
} }
}// Top-level build file where you can add configuration options common to all sub-projects/modules. }// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins { plugins {
id 'com.android.application' version '8.0.2' apply false id 'com.android.application' version '8.1.4' apply false
id 'com.android.library' version '8.0.2' apply false id 'com.android.library' version '8.1.4' apply false
id 'com.google.android.libraries.mapsplatform.secrets-gradle-plugin' version '2.0.1' apply false id 'com.google.android.libraries.mapsplatform.secrets-gradle-plugin' version '2.0.1' apply false
} }