Compare commits
No commits in common. "master" and "EkamoExample" have entirely different histories.
master
...
EkamoExamp
|
@ -5,15 +5,14 @@
|
|||
<option name="linkedExternalProjectsSettings">
|
||||
<GradleProjectSettings>
|
||||
<option name="testRunner" value="GRADLE" />
|
||||
<option name="distributionType" value="DEFAULT_WRAPPED" />
|
||||
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
||||
<option name="gradleJvm" value="jbr-17" />
|
||||
<option name="modules">
|
||||
<set>
|
||||
<option value="$PROJECT_DIR$" />
|
||||
<option value="$PROJECT_DIR$/app" />
|
||||
</set>
|
||||
</option>
|
||||
<option name="resolveExternalAnnotations" value="false" />
|
||||
</GradleProjectSettings>
|
||||
</option>
|
||||
</component>
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<project version="4">
|
||||
<component name="ExternalStorageConfigurationManager" enabled="true" />
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_17" default="true" project-jdk-name="jbr-17" project-jdk-type="JavaSDK">
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_17" project-jdk-name="jbr-17" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/build/classes" />
|
||||
</component>
|
||||
<component name="ProjectType">
|
||||
|
|
|
@ -1,19 +1,15 @@
|
|||
plugins {
|
||||
id 'com.android.application'
|
||||
|
||||
id 'com.google.gms.google-services'
|
||||
|
||||
id 'com.google.android.libraries.mapsplatform.secrets-gradle-plugin'
|
||||
}
|
||||
|
||||
android {
|
||||
namespace 'com.example.oplogy'
|
||||
compileSdk 34
|
||||
compileSdk 33
|
||||
|
||||
defaultConfig {
|
||||
applicationId "com.example.oplogy"
|
||||
minSdk 26
|
||||
targetSdk 34
|
||||
targetSdk 33
|
||||
versionCode 1
|
||||
versionName "1.0"
|
||||
|
||||
|
@ -30,33 +26,14 @@ android {
|
|||
sourceCompatibility JavaVersion.VERSION_1_8
|
||||
targetCompatibility JavaVersion.VERSION_1_8
|
||||
}
|
||||
buildFeatures {
|
||||
viewBinding true
|
||||
}
|
||||
}
|
||||
|
||||
dependencies {
|
||||
implementation 'com.google.maps:google-maps-services:0.15.0'
|
||||
|
||||
implementation 'androidx.appcompat:appcompat:1.6.1'
|
||||
implementation 'com.google.android.material:material:1.5.0'
|
||||
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
|
||||
implementation 'com.google.firebase:firebase-firestore:24.4.1'
|
||||
implementation 'com.google.android.gms:play-services-maps:18.2.0'
|
||||
testImplementation 'junit:junit:4.13.2'
|
||||
androidTestImplementation 'androidx.test.ext:junit:1.1.5'
|
||||
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ライブラリの追加
|
||||
}
|
||||
}
|
|
@ -1,29 +0,0 @@
|
|||
{
|
||||
"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"
|
||||
}
|
|
@ -2,11 +2,6 @@
|
|||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
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
|
||||
android:allowBackup="true"
|
||||
android:dataExtractionRules="@xml/data_extraction_rules"
|
||||
|
@ -16,46 +11,10 @@
|
|||
android:roundIcon="@mipmap/ic_launcher_round"
|
||||
android:supportsRtl="true"
|
||||
android:theme="@style/Theme.Oplogy"
|
||||
tools:ignore="ExtraText"
|
||||
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.
|
||||
|
||||
To get one, follow the directions here:
|
||||
|
||||
https://developers.google.com/maps/documentation/android-sdk/get-api-key
|
||||
|
||||
Once you have your API key (it starts with "AIza"), define a new property in your
|
||||
project's local.properties file (e.g. MAPS_API_KEY=Aiza...), and replace the
|
||||
"YOUR_API_KEY" string in this file with "${MAPS_API_KEY}".
|
||||
-->
|
||||
<meta-data
|
||||
android:name="com.google.android.geo.API_KEY"
|
||||
android:value="AIzaSyBQ1Ak-I2NL5TP4K59ZI0VgzKk6HNZuusw" />
|
||||
|
||||
<activity
|
||||
android:name=".Maps"
|
||||
android:exported="false"
|
||||
android:label="@string/title_activity_maps" />
|
||||
<activity
|
||||
android:name=".SubmissionActivity"
|
||||
android:exported="false" />
|
||||
<activity
|
||||
android:name=".CreateUUID"
|
||||
android:exported="false" />
|
||||
<activity
|
||||
android:name=".DialogFragment"
|
||||
android:exported="false" />
|
||||
<activity
|
||||
android:name=".MainActivity"
|
||||
android:exported="true"
|
||||
tools:ignore="DuplicateActivity">
|
||||
android:exported="true">
|
||||
<intent-filter>
|
||||
<action android:name="android.intent.action.MAIN" />
|
||||
|
||||
|
|
Before Width: | Height: | Size: 367 KiB |
|
@ -1,10 +0,0 @@
|
|||
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();
|
||||
}
|
|
@ -1,39 +0,0 @@
|
|||
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;
|
||||
}
|
||||
}
|
|
@ -1,420 +0,0 @@
|
|||
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を比較するComparator→timezoneが短い順に並べる
|
||||
Comparator<MyDataClass> comparator = Comparator.comparing(MyDataClass::getTimezone);
|
||||
// myDataListをtimezoneの値でソート
|
||||
myDataList.sort(comparator);
|
||||
}
|
||||
|
||||
private void secondTimeZoneSort(List<MyDataClass> myDataList) {
|
||||
// timezoneを比較するComparator→timezoneが短い順に並べる
|
||||
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=852−1,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());
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,28 +0,0 @@
|
|||
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;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,35 +0,0 @@
|
|||
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) {
|
||||
|
||||
}
|
||||
}
|
||||
|
|
@ -1,13 +0,0 @@
|
|||
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);
|
||||
}
|
||||
}
|
|
@ -1,81 +0,0 @@
|
|||
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;
|
||||
}
|
||||
}
|
|
@ -1,48 +0,0 @@
|
|||
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;
|
||||
}
|
||||
}
|
|
@ -1,19 +0,0 @@
|
|||
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));
|
||||
}
|
||||
}
|
|
@ -1,393 +1,38 @@
|
|||
package com.example.oplogy;
|
||||
|
||||
import android.app.ProgressDialog;
|
||||
import android.content.Intent;
|
||||
import android.content.SharedPreferences;
|
||||
import android.os.Bundle;
|
||||
import android.util.Log;
|
||||
import android.view.View;
|
||||
import android.widget.ImageView;
|
||||
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.firebase.firestore.FirebaseFirestore;
|
||||
import com.google.gson.Gson;
|
||||
|
||||
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;
|
||||
import android.annotation.SuppressLint;
|
||||
import android.os.Bundle;
|
||||
import android.view.View;
|
||||
import android.widget.Button;
|
||||
import android.widget.EditText;
|
||||
import android.widget.TextView;
|
||||
|
||||
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
|
||||
|
||||
|
||||
// ダイアログの宣言
|
||||
private AlertDialog alertDialog;
|
||||
// ID作成のTextViewとImageView
|
||||
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;
|
||||
|
||||
|
||||
Button button;
|
||||
// TextView textView;
|
||||
EditText editText;
|
||||
@SuppressLint("MissingInflatedId")
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
setContentView(R.layout.main);
|
||||
setContentView(R.layout.activity_main);
|
||||
|
||||
|
||||
// ルート作成用のインテント
|
||||
root = findViewById(R.id.root);
|
||||
root.setOnClickListener(this);
|
||||
imageRoot = findViewById(R.id.imageRoot);
|
||||
imageRoot.setOnClickListener(this);
|
||||
|
||||
// 提出状況のインテント
|
||||
submission = findViewById(R.id.submission);
|
||||
submission.setOnClickListener(this);
|
||||
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();
|
||||
}
|
||||
|
||||
});
|
||||
button = findViewById(R.id.button1);
|
||||
button.setOnClickListener(this);
|
||||
editText = findViewById(R.id.textview1);
|
||||
|
||||
}
|
||||
|
||||
|
||||
// クリック処理
|
||||
@Override
|
||||
public void onClick(View view) {
|
||||
// ルート作成のクリック処理
|
||||
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をシャットダウン
|
||||
}
|
||||
|
||||
return submissionStudents;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
protected void onDestroy() {
|
||||
super.onDestroy();
|
||||
if (alertDialog != null && alertDialog.isShowing()) {
|
||||
alertDialog.dismiss();
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
if (v == button){
|
||||
editText.setText("押した");
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,504 +0,0 @@
|
|||
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−9 地下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桁の整数表記から○月〇日(20240707→07月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桁の整数から○月〇日●時〇分(6041200→06月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;
|
||||
}
|
||||
}
|
|
@ -1,259 +0,0 @@
|
|||
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;
|
||||
}
|
||||
}
|
|
@ -1,320 +0,0 @@
|
|||
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");
|
||||
}
|
||||
|
||||
}
|
|
@ -1,73 +0,0 @@
|
|||
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;
|
||||
}
|
||||
}
|
|
@ -1,52 +0,0 @@
|
|||
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();
|
||||
|
||||
|
||||
}
|
|
@ -1,190 +0,0 @@
|
|||
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();
|
||||
}
|
||||
|
||||
}
|
|
@ -1,55 +0,0 @@
|
|||
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();
|
||||
}
|
||||
}
|
|
@ -1,72 +0,0 @@
|
|||
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);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,49 +0,0 @@
|
|||
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));
|
||||
}
|
||||
}
|
|
@ -1,30 +0,0 @@
|
|||
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) {
|
||||
}
|
||||
}
|
Before Width: | Height: | Size: 48 KiB |
Before Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 2.1 KiB |
Before Width: | Height: | Size: 2.0 KiB |
Before Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 9.5 KiB |
Before Width: | Height: | Size: 46 KiB |
27
app/src/main/res/layout/activity_main.xml
Normal file
|
@ -0,0 +1,27 @@
|
|||
<?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">
|
||||
|
||||
<Button
|
||||
android:id="@+id/button1"
|
||||
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>
|
|
@ -1,358 +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=".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>
|
|
@ -1,126 +0,0 @@
|
|||
<?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>
|
|
@ -1,9 +0,0 @@
|
|||
<?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>
|
|
@ -1,10 +0,0 @@
|
|||
<?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>
|
|
@ -1,148 +0,0 @@
|
|||
<?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>
|
|
@ -1,58 +0,0 @@
|
|||
<?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>
|
|
@ -1,30 +0,0 @@
|
|||
<?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>
|
|
@ -1,42 +0,0 @@
|
|||
<?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>
|
|
@ -1,5 +1,6 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<background android:drawable="@color/ic_launcher_background"/>
|
||||
<foreground android:drawable="@mipmap/ic_launcher_foreground"/>
|
||||
<background android:drawable="@drawable/ic_launcher_background" />
|
||||
<foreground android:drawable="@drawable/ic_launcher_foreground" />
|
||||
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
|
||||
</adaptive-icon>
|
|
@ -1,5 +1,6 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<background android:drawable="@color/ic_launcher_background"/>
|
||||
<foreground android:drawable="@mipmap/ic_launcher_foreground"/>
|
||||
<background android:drawable="@drawable/ic_launcher_background" />
|
||||
<foreground android:drawable="@drawable/ic_launcher_foreground" />
|
||||
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
|
||||
</adaptive-icon>
|
Before Width: | Height: | Size: 5.7 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 7.8 KiB After Width: | Height: | Size: 2.8 KiB |
Before Width: | Height: | Size: 3.0 KiB After Width: | Height: | Size: 982 B |
Before Width: | Height: | Size: 7.4 KiB |
Before Width: | Height: | Size: 4.2 KiB After Width: | Height: | Size: 1.7 KiB |
Before Width: | Height: | Size: 8.6 KiB After Width: | Height: | Size: 1.9 KiB |
Before Width: | Height: | Size: 23 KiB |
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 3.8 KiB |
Before Width: | Height: | Size: 16 KiB After Width: | Height: | Size: 2.8 KiB |
Before Width: | Height: | Size: 45 KiB |
Before Width: | Height: | Size: 22 KiB After Width: | Height: | Size: 5.8 KiB |
Before Width: | Height: | Size: 26 KiB After Width: | Height: | Size: 3.8 KiB |
Before Width: | Height: | Size: 75 KiB |
Before Width: | Height: | Size: 34 KiB After Width: | Height: | Size: 7.6 KiB |
|
@ -1,4 +0,0 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<resources>
|
||||
<color name="ic_launcher_background">#FFFFFF</color>
|
||||
</resources>
|
|
@ -1,19 +1,3 @@
|
|||
<resources>
|
||||
<string name="app_name">Oplogy</string>
|
||||
<string name="maps_api_key">AIzaSyBqLqPm76UFpwbpU8b3oiH0wbkhosrPWpU</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>
|
||||
<string name="app_name">oplogy</string>
|
||||
</resources>
|
14
build.gradle
|
@ -1,11 +1,5 @@
|
|||
buildscript {
|
||||
dependencies {
|
||||
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 {
|
||||
id 'com.android.application' version '8.1.4' 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.android.application' version '8.0.2' apply false
|
||||
id 'com.android.library' version '8.0.2' apply false
|
||||
}
|