Compare commits
	
		
			No commits in common. "master" and "SubWorker" have entirely different histories.
		
	
	
		
	
		
							
								
								
									
										15
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,15 @@ | |||||||
|  | *.iml | ||||||
|  | .gradle | ||||||
|  | /local.properties | ||||||
|  | /.idea/caches | ||||||
|  | /.idea/libraries | ||||||
|  | /.idea/modules.xml | ||||||
|  | /.idea/workspace.xml | ||||||
|  | /.idea/navEditor.xml | ||||||
|  | /.idea/assetWizardSettings.xml | ||||||
|  | .DS_Store | ||||||
|  | /build | ||||||
|  | /captures | ||||||
|  | .externalNativeBuild | ||||||
|  | .cxx | ||||||
|  | local.properties | ||||||
							
								
								
									
										3
									
								
								.idea/.gitignore
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,3 @@ | |||||||
|  | # Default ignored files | ||||||
|  | /shelf/ | ||||||
|  | /workspace.xml | ||||||
							
								
								
									
										1
									
								
								.idea/.name
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1 @@ | |||||||
|  | Schockwelle | ||||||
							
								
								
									
										6
									
								
								.idea/compiler.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,6 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="CompilerConfiguration"> | ||||||
|  |     <bytecodeTargetLevel target="11" /> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
							
								
								
									
										22
									
								
								.idea/gradle.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,22 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="GradleMigrationSettings" migrationVersion="1" /> | ||||||
|  |   <component name="GradleSettings"> | ||||||
|  |     <option name="linkedExternalProjectsSettings"> | ||||||
|  |       <GradleProjectSettings> | ||||||
|  |         <option name="testRunner" value="PLATFORM" /> | ||||||
|  |         <option name="distributionType" value="DEFAULT_WRAPPED" /> | ||||||
|  |         <option name="externalProjectPath" value="$PROJECT_DIR$" /> | ||||||
|  |         <option name="gradleJvm" value="1.8" /> | ||||||
|  |         <option name="modules"> | ||||||
|  |           <set> | ||||||
|  |             <option value="$PROJECT_DIR$" /> | ||||||
|  |             <option value="$PROJECT_DIR$/app" /> | ||||||
|  |           </set> | ||||||
|  |         </option> | ||||||
|  |         <option name="resolveModulePerSourceSet" value="false" /> | ||||||
|  |         <option name="useQualifiedModuleNames" value="true" /> | ||||||
|  |       </GradleProjectSettings> | ||||||
|  |     </option> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
							
								
								
									
										25
									
								
								.idea/jarRepositories.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,25 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="RemoteRepositoriesConfiguration"> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="central" /> | ||||||
|  |       <option name="name" value="Maven Central repository" /> | ||||||
|  |       <option name="url" value="https://repo1.maven.org/maven2" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="jboss.community" /> | ||||||
|  |       <option name="name" value="JBoss Community repository" /> | ||||||
|  |       <option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="BintrayJCenter" /> | ||||||
|  |       <option name="name" value="BintrayJCenter" /> | ||||||
|  |       <option name="url" value="https://jcenter.bintray.com/" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="Google" /> | ||||||
|  |       <option name="name" value="Google" /> | ||||||
|  |       <option name="url" value="https://dl.google.com/dl/android/maven2/" /> | ||||||
|  |     </remote-repository> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
							
								
								
									
										9
									
								
								.idea/misc.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,9 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="ProjectRootManager" version="2" languageLevel="JDK_11" default="true" project-jdk-name="1.8" project-jdk-type="JavaSDK"> | ||||||
|  |     <output url="file://$PROJECT_DIR$/build/classes" /> | ||||||
|  |   </component> | ||||||
|  |   <component name="ProjectType"> | ||||||
|  |     <option name="id" value="Android" /> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
							
								
								
									
										10
									
								
								.idea/runConfigurations.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,10 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="RunConfigurationProducerService"> | ||||||
|  |     <option name="ignoredProducers"> | ||||||
|  |       <set> | ||||||
|  |         <option value="com.android.tools.idea.compose.preview.runconfiguration.ComposePreviewRunConfigurationProducer" /> | ||||||
|  |       </set> | ||||||
|  |     </option> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
							
								
								
									
										6
									
								
								.idea/vcs.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,6 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="VcsDirectoryMappings"> | ||||||
|  |     <mapping directory="$PROJECT_DIR$" vcs="Git" /> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
| @ -1,3 +0,0 @@ | |||||||
| # mMDT5_PR_MSY1_Gruppe1-AlphaVersion |  | ||||||
| 
 |  | ||||||
| AlphaVersion der SchokwellenApp |  | ||||||
							
								
								
									
										1
									
								
								app/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1 @@ | |||||||
|  | /build | ||||||
							
								
								
									
										45
									
								
								app/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,45 @@ | |||||||
|  | plugins { | ||||||
|  |     id 'com.android.application' | ||||||
|  |     id 'com.google.gms.google-services' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | android { | ||||||
|  |     compileSdkVersion 30 | ||||||
|  |     buildToolsVersion "30.0.3" | ||||||
|  | 
 | ||||||
|  |     defaultConfig { | ||||||
|  |         applicationId "de.edotzlaff.schockwelle" | ||||||
|  |         minSdkVersion 23 | ||||||
|  |         targetSdkVersion 30 | ||||||
|  |         versionCode 1 | ||||||
|  |         versionName "1.0" | ||||||
|  | 
 | ||||||
|  |         testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     buildTypes { | ||||||
|  |         release { | ||||||
|  |             minifyEnabled false | ||||||
|  |             proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     compileOptions { | ||||||
|  |         sourceCompatibility JavaVersion.VERSION_1_8 | ||||||
|  |         targetCompatibility JavaVersion.VERSION_1_8 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | dependencies { | ||||||
|  | 
 | ||||||
|  |     implementation 'androidx.appcompat:appcompat:1.3.0' | ||||||
|  |     implementation 'com.google.android.material:material:1.3.0' | ||||||
|  |     implementation 'androidx.constraintlayout:constraintlayout:2.0.4' | ||||||
|  |     implementation 'com.google.android.gms:play-services-maps:17.0.1' | ||||||
|  |     implementation 'com.google.firebase:firebase-database:20.0.0' | ||||||
|  |     implementation 'com.google.firebase:firebase-functions:20.0.0' | ||||||
|  |     testImplementation 'junit:junit:4.+' | ||||||
|  |     androidTestImplementation 'androidx.test.ext:junit:1.1.2' | ||||||
|  |     androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0' | ||||||
|  |     implementation "com.google.android.gms:play-services-location:15.0.1" //Important to find the location from the device | ||||||
|  |     implementation platform('com.google.firebase:firebase-bom:28.1.0') | ||||||
|  | } | ||||||
							
								
								
									
										40
									
								
								app/google-services.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,40 @@ | |||||||
|  | { | ||||||
|  |   "project_info": { | ||||||
|  |     "project_number": "957720376634", | ||||||
|  |     "firebase_url": "https://schockwelle-mdt5-g1-default-rtdb.europe-west1.firebasedatabase.app", | ||||||
|  |     "project_id": "schockwelle-mdt5-g1", | ||||||
|  |     "storage_bucket": "schockwelle-mdt5-g1.appspot.com" | ||||||
|  |   }, | ||||||
|  |   "client": [ | ||||||
|  |     { | ||||||
|  |       "client_info": { | ||||||
|  |         "mobilesdk_app_id": "1:957720376634:android:fdc03f689ff71b2f70cc03", | ||||||
|  |         "android_client_info": { | ||||||
|  |           "package_name": "de.edotzlaff.schockwelle" | ||||||
|  |         } | ||||||
|  |       }, | ||||||
|  |       "oauth_client": [ | ||||||
|  |         { | ||||||
|  |           "client_id": "957720376634-gvj86hvfrnt5npvqfbsb8lnu77fgaumh.apps.googleusercontent.com", | ||||||
|  |           "client_type": 3 | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "api_key": [ | ||||||
|  |         { | ||||||
|  |           "current_key": "AIzaSyDNnG6F_VIzKbu4r7QBqsUZ3z6ELFbgyuc" | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "services": { | ||||||
|  |         "appinvite_service": { | ||||||
|  |           "other_platform_oauth_client": [ | ||||||
|  |             { | ||||||
|  |               "client_id": "957720376634-gvj86hvfrnt5npvqfbsb8lnu77fgaumh.apps.googleusercontent.com", | ||||||
|  |               "client_type": 3 | ||||||
|  |             } | ||||||
|  |           ] | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|  |   "configuration_version": "1" | ||||||
|  | } | ||||||
							
								
								
									
										21
									
								
								app/proguard-rules.pro
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,21 @@ | |||||||
|  | # Add project specific ProGuard rules here. | ||||||
|  | # You can control the set of applied configuration files using the | ||||||
|  | # proguardFiles setting in build.gradle. | ||||||
|  | # | ||||||
|  | # For more details, see | ||||||
|  | #   http://developer.android.com/guide/developing/tools/proguard.html | ||||||
|  | 
 | ||||||
|  | # If your project uses WebView with JS, uncomment the following | ||||||
|  | # and specify the fully qualified class name to the JavaScript interface | ||||||
|  | # class: | ||||||
|  | #-keepclassmembers class fqcn.of.javascript.interface.for.webview { | ||||||
|  | #   public *; | ||||||
|  | #} | ||||||
|  | 
 | ||||||
|  | # Uncomment this to preserve the line number information for | ||||||
|  | # debugging stack traces. | ||||||
|  | #-keepattributes SourceFile,LineNumberTable | ||||||
|  | 
 | ||||||
|  | # If you keep the line number information, uncomment this to | ||||||
|  | # hide the original source file name. | ||||||
|  | #-renamesourcefileattribute SourceFile | ||||||
| @ -0,0 +1,26 @@ | |||||||
|  | package de.edotzlaff.schockwelle; | ||||||
|  | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | 
 | ||||||
|  | import androidx.test.platform.app.InstrumentationRegistry; | ||||||
|  | import androidx.test.ext.junit.runners.AndroidJUnit4; | ||||||
|  | 
 | ||||||
|  | import org.junit.Test; | ||||||
|  | import org.junit.runner.RunWith; | ||||||
|  | 
 | ||||||
|  | import static org.junit.Assert.*; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Instrumented test, which will execute on an Android device. | ||||||
|  |  * | ||||||
|  |  * @see <a href="http://d.android.com/tools/testing">Testing documentation</a> | ||||||
|  |  */ | ||||||
|  | @RunWith(AndroidJUnit4.class) | ||||||
|  | public class ExampleInstrumentedTest { | ||||||
|  |     @Test | ||||||
|  |     public void useAppContext() { | ||||||
|  |         // Context of the app under test. | ||||||
|  |         Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext(); | ||||||
|  |         assertEquals("de.edotzlaff.schockwelle", appContext.getPackageName()); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										4
									
								
								app/src/debug/res/values/google_maps_api.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,4 @@ | |||||||
|  | <resources> | ||||||
|  | 
 | ||||||
|  |     <string name="google_maps_key" templateMergeStrategy="preserve" translatable="false">AIzaSyCCnjanFAzxuH91tD206IjaAU4_ymSgug0</string> | ||||||
|  | </resources> | ||||||
							
								
								
									
										53
									
								
								app/src/main/AndroidManifest.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,53 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <manifest xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     package="de.edotzlaff.schockwelle"> | ||||||
|  | 
 | ||||||
|  |     <!-- | ||||||
|  |          The ACCESS_COARSE/FINE_LOCATION permissions are not required to use | ||||||
|  |          Google Maps Android API v2, but you must specify either coarse or fine | ||||||
|  |          location permissions for the "MyLocation" functionality. | ||||||
|  |     --> | ||||||
|  |     <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> | ||||||
|  |     <uses-permission android:name="android.permission.INTERNET" /> | ||||||
|  |     <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> | ||||||
|  | 
 | ||||||
|  |     <uses-permission android:name="android.permission.VIBRATE" /> | ||||||
|  | 
 | ||||||
|  |     <application | ||||||
|  |         android:allowBackup="true" | ||||||
|  |         android:icon="@mipmap/schockicon" | ||||||
|  |         android:label="@string/app_name" | ||||||
|  |         android:roundIcon="@mipmap/schockicon" | ||||||
|  |         android:supportsRtl="true" | ||||||
|  |         android:theme="@style/Theme.Schockwelle"> | ||||||
|  | 
 | ||||||
|  |         <!-- | ||||||
|  |              The API key for Google Maps-based APIs is defined as a string resource. | ||||||
|  |              (See the file "res/values/google_maps_api.xml"). | ||||||
|  |              Note that the API key is linked to the encryption key used to sign the APK. | ||||||
|  |              You need a different API key for each encryption key, including the release key that is used to | ||||||
|  |              sign the APK for publishing. | ||||||
|  |              You can define the keys for the debug and release targets in src/debug/ and src/release/. | ||||||
|  |         --> | ||||||
|  |         <meta-data | ||||||
|  |             android:name="com.google.android.geo.API_KEY" | ||||||
|  |             android:value="@string/google_maps_key" /> | ||||||
|  | 
 | ||||||
|  |         <activity | ||||||
|  |             android:name=".SensorMapsActivity" | ||||||
|  |             android:label="@string/title_activity_sensor_maps"></activity> | ||||||
|  |         <activity | ||||||
|  |             android:name=".EarthquakeMapsActivity" | ||||||
|  |             android:label="@string/title_activity_earthquake_maps"/> | ||||||
|  |         <activity android:name=".MainActivity"> | ||||||
|  |             <intent-filter> | ||||||
|  |                 <action android:name="android.intent.action.MAIN" /> | ||||||
|  | 
 | ||||||
|  |                 <category android:name="android.intent.category.LAUNCHER" /> | ||||||
|  |             </intent-filter> | ||||||
|  |         </activity> | ||||||
|  |     </application> | ||||||
|  | 
 | ||||||
|  | </manifest> | ||||||
|  | 
 | ||||||
|  | <!--android:parentActivityName=".MainActivity"--> | ||||||
							
								
								
									
										86
									
								
								app/src/main/java/de/edotzlaff/schockwelle/Devices.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,86 @@ | |||||||
|  | package de.edotzlaff.schockwelle; | ||||||
|  | 
 | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  | 
 | ||||||
|  | public class Devices { | ||||||
|  |     private String ip; | ||||||
|  |     private boolean vibration; | ||||||
|  |     private long timestamp; | ||||||
|  |     private double breitengrad; | ||||||
|  |     private double laengengrad; | ||||||
|  |     private int amplitude; | ||||||
|  |     private String localdatetime; | ||||||
|  |     private boolean idvergeben; | ||||||
|  |     private String androidid; | ||||||
|  | 
 | ||||||
|  |     public Devices() { | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public Devices(String ip, boolean vibration, long timestamp, double breitengrad, double laengengrad, int amplitude, String localdatetime, String androidid) { | ||||||
|  |         this.ip = ip; | ||||||
|  |         this.vibration = vibration; | ||||||
|  |         this.timestamp = timestamp; | ||||||
|  |         this.breitengrad = breitengrad; | ||||||
|  |         this.laengengrad = laengengrad; | ||||||
|  |         this.amplitude = amplitude; | ||||||
|  |         this.localdatetime = localdatetime; | ||||||
|  |         this.androidid = androidid; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getIp() { | ||||||
|  |         return ip; | ||||||
|  |     } | ||||||
|  |     public void setIp(String ip) { | ||||||
|  |         this.ip = ip; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public boolean isVibration() { | ||||||
|  |         return vibration; | ||||||
|  |     } | ||||||
|  |     public void setVibration(boolean vibration) { | ||||||
|  |         this.vibration = vibration; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public long getTimestamp() { | ||||||
|  |         return timestamp; | ||||||
|  |     } | ||||||
|  |     public void setTimestamp(long timestamp) { | ||||||
|  |         this.timestamp = timestamp; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public double getBreitengrad() { | ||||||
|  |         return breitengrad; | ||||||
|  |     } | ||||||
|  |     public void setBreitengrad(double breitengrad) { | ||||||
|  |         this.breitengrad = breitengrad; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public double getLaengengrad() { | ||||||
|  |         return laengengrad; | ||||||
|  |     } | ||||||
|  |     public void setLaengengrad(double laengengrad) { | ||||||
|  |         this.laengengrad = laengengrad; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int getAmplitude() { | ||||||
|  |         return amplitude; | ||||||
|  |     } | ||||||
|  |     public void setAmplitude(int amplitude) { | ||||||
|  |         this.amplitude = amplitude; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getLocaldatetime() { | ||||||
|  |         return localdatetime; | ||||||
|  |     } | ||||||
|  |     public void setLocaldatetime(String localdatetime) { | ||||||
|  |         this.localdatetime = localdatetime; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getAndroidid() { | ||||||
|  |         return androidid; | ||||||
|  |     } | ||||||
|  |     public void setAndroidid(String androidid) { | ||||||
|  |         this.androidid = androidid; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,418 @@ | |||||||
|  | package de.edotzlaff.schockwelle; | ||||||
|  | 
 | ||||||
|  | import android.Manifest; | ||||||
|  | import android.app.ActionBar; | ||||||
|  | import android.content.Context; | ||||||
|  | import android.content.pm.PackageManager; | ||||||
|  | import android.hardware.Sensor; | ||||||
|  | import android.hardware.SensorEvent; | ||||||
|  | import android.hardware.SensorEventListener; | ||||||
|  | import android.hardware.SensorManager; | ||||||
|  | import android.location.Location; | ||||||
|  | import android.net.wifi.WifiManager; | ||||||
|  | import android.os.Build; | ||||||
|  | import android.os.Bundle; | ||||||
|  | import android.os.CountDownTimer; | ||||||
|  | import android.os.SystemClock; | ||||||
|  | import android.provider.ContactsContract; | ||||||
|  | import android.provider.Settings; | ||||||
|  | import android.util.Log; | ||||||
|  | import android.widget.TextView; | ||||||
|  | import android.widget.Toast; | ||||||
|  | 
 | ||||||
|  | import androidx.annotation.NonNull; | ||||||
|  | import androidx.core.app.ActivityCompat; | ||||||
|  | import androidx.core.content.ContextCompat; | ||||||
|  | import androidx.fragment.app.FragmentActivity; | ||||||
|  | 
 | ||||||
|  | import com.google.android.gms.location.FusedLocationProviderClient; | ||||||
|  | import com.google.android.gms.location.LocationServices; | ||||||
|  | import com.google.android.gms.maps.CameraUpdateFactory; | ||||||
|  | import com.google.android.gms.maps.GoogleMap; | ||||||
|  | import com.google.android.gms.maps.OnMapReadyCallback; | ||||||
|  | import com.google.android.gms.maps.SupportMapFragment; | ||||||
|  | import com.google.android.gms.maps.model.LatLng; | ||||||
|  | import com.google.android.gms.maps.model.MarkerOptions; | ||||||
|  | import com.google.android.gms.tasks.OnCompleteListener; | ||||||
|  | import com.google.android.gms.tasks.Task; | ||||||
|  | import com.google.firebase.database.DataSnapshot; | ||||||
|  | import com.google.firebase.database.DatabaseError; | ||||||
|  | import com.google.firebase.database.DatabaseReference; | ||||||
|  | import com.google.firebase.database.FirebaseDatabase; | ||||||
|  | import com.google.firebase.database.ValueEventListener; | ||||||
|  | 
 | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  | import java.util.Calendar; | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.Objects; | ||||||
|  | 
 | ||||||
|  | public class EarthquakeMapsActivity extends FragmentActivity implements OnMapReadyCallback { | ||||||
|  | 
 | ||||||
|  |     private static final String TAG = "MainActivity"; | ||||||
|  |     private static final String FINE_LOCATION = Manifest.permission.ACCESS_FINE_LOCATION; | ||||||
|  |     private static final int LOCATION_PERMISSION_REQUEST_CODE = 1234; | ||||||
|  |     private Boolean mLocationPermissionsGranted = false; | ||||||
|  |     private GoogleMap mMap; | ||||||
|  |     private FusedLocationProviderClient mFusedLocationProviderClient; | ||||||
|  | 
 | ||||||
|  |     Long currentTime; | ||||||
|  |     Location currentLocation; | ||||||
|  |     private DatabaseReference mDatenbank; | ||||||
|  |     private double breitengrad; | ||||||
|  |     private double laengengrad; | ||||||
|  |     private boolean useOwnGPS; | ||||||
|  |     private int indexID = 1; | ||||||
|  | 
 | ||||||
|  |     //########################################################################################################################################################################## | ||||||
|  |     //##################################################################  vvv ShakeParameter vvv  ############################################################################## | ||||||
|  |     private SensorManager mSensorManager; | ||||||
|  |     private static final float mUpperThreshold = 10.5f; // für Emulator auf 1.5 setzen | ||||||
|  |     private static final float mLowerThreshold = 5.5f; // für Emulator auf 0.5 setzen | ||||||
|  |     private static final long mShakeDetectionLockTimeMicroSeconds = 10000; | ||||||
|  |     private float mAccel; | ||||||
|  |     private float mAccelCurrent; | ||||||
|  |     private float mAccelLast; | ||||||
|  |     private boolean mShakeDetectionIsActive = false; | ||||||
|  |     private boolean mShakeDetected = false; | ||||||
|  |     //private boolean allowShakeEvent = true; | ||||||
|  |     //##################################################################  ^^^^ ShakeParameter ^^^^  ############################################################################ | ||||||
|  |     //########################################################################################################################################################################## | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     protected void onCreate(Bundle savedInstanceState) { | ||||||
|  |         super.onCreate(savedInstanceState); | ||||||
|  |         setContentView(R.layout.activity_earthquake_maps); | ||||||
|  | 
 | ||||||
|  |         getDataBaseValuesNoListener(); | ||||||
|  |         sensorManagementInit(); | ||||||
|  |         getLocationPermission(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  |     //##################################################################  vvv ShakeCode vvv  ############################################################################## | ||||||
|  |     private void sensorManagementInit() | ||||||
|  |     { | ||||||
|  |         TextView txtEarthquake =  (TextView) findViewById(R.id.txtEarthquake); | ||||||
|  |         mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE); | ||||||
|  |         Objects.requireNonNull(mSensorManager).registerListener(mSensorListener, mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER), SensorManager.SENSOR_DELAY_NORMAL); | ||||||
|  |         mAccel = 1f; | ||||||
|  |         mAccelCurrent = SensorManager.GRAVITY_EARTH; | ||||||
|  |         mAccelLast = SensorManager.GRAVITY_EARTH; | ||||||
|  |         mShakeDetectionIsActive = true; | ||||||
|  |         mShakeDetected = false; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private CountDownTimer mLockTimer = new CountDownTimer(mShakeDetectionLockTimeMicroSeconds, 1000) | ||||||
|  |     { | ||||||
|  |         public void onTick(long millisUntilFinished) { | ||||||
|  |             ((TextView)   findViewById(R.id.txtEarthquake)).setText("Earthquake started! Detection locked for " + millisUntilFinished / 1000 + " s"); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public void onFinish() { | ||||||
|  |             mShakeDetectionIsActive = true; | ||||||
|  |             mShakeDetected = false; | ||||||
|  |             Toast.makeText(getApplicationContext(), "Shake Detection unlocked", Toast.LENGTH_SHORT).show(); | ||||||
|  |             ( (TextView)   findViewById(R.id.txtEarthquake)).setText("Shake your Smartphone for an Earthquake"); | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     private final SensorEventListener mSensorListener = new SensorEventListener() { | ||||||
|  |         @Override | ||||||
|  |         public void onSensorChanged(SensorEvent event) { | ||||||
|  |             float x = event.values[0]; | ||||||
|  |             float y = event.values[1]; | ||||||
|  |             float z = event.values[2]; | ||||||
|  |             mAccelLast = mAccelCurrent; | ||||||
|  |             mAccelCurrent = (float) Math.sqrt((double) (x * x + y * y + z * z)); | ||||||
|  |             float delta = mAccelCurrent - mAccelLast; | ||||||
|  |             mAccel = mAccel * 0.9f + delta; | ||||||
|  |             //  Log.d(TAG,"mAccel: "+ mAccel); | ||||||
|  |             if (mShakeDetectionIsActive) { | ||||||
|  |                 if(Math.abs(mAccel) > mUpperThreshold) { | ||||||
|  |                     new CountDownTimer(50, 10) { | ||||||
|  | 
 | ||||||
|  |                         public void onTick(long millisUntilFinished) { | ||||||
|  |                             if (Math.abs(mAccel) > mUpperThreshold) { | ||||||
|  |                                 mShakeDetectionIsActive = false; | ||||||
|  |                             } else if (Math.abs(mAccel) < mLowerThreshold) { | ||||||
|  |                                 mShakeDetectionIsActive = true; | ||||||
|  |                                 this.cancel(); | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  | 
 | ||||||
|  |                         public void onFinish() { | ||||||
|  |                             if (Math.abs(mAccel) > mUpperThreshold) { | ||||||
|  |                                 mShakeDetectionIsActive = false; | ||||||
|  |                                 mShakeDetected = true; | ||||||
|  |                                 Toast.makeText(getApplicationContext(), "Shake event detected", Toast.LENGTH_SHORT).show(); | ||||||
|  |                                 writeEarthquakeToDatabase(); | ||||||
|  |                                 mLockTimer.start(); | ||||||
|  |                             } else { | ||||||
|  |                                 mShakeDetectionIsActive = true; | ||||||
|  |                                 mShakeDetected = false; | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     }.start(); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         @Override | ||||||
|  |         public void onAccuracyChanged(Sensor sensor, int accuracy) { | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     private void writeEarthquakeToDatabase() | ||||||
|  |     { | ||||||
|  |         setDataBaseValues(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     protected void onResume() { | ||||||
|  |         mSensorManager.registerListener(mSensorListener, mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER), | ||||||
|  |                 SensorManager.SENSOR_DELAY_NORMAL); | ||||||
|  |         super.onResume(); | ||||||
|  |     } | ||||||
|  |     @Override | ||||||
|  |     protected void onPause() { | ||||||
|  |         mSensorManager.unregisterListener(mSensorListener); | ||||||
|  |         super.onPause(); | ||||||
|  |     } | ||||||
|  |     //##################################################################  ^^^^ ShakeCode ^^^^  ############################################################################ | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  | 
 | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  |     //##################################################################  vvv GPS Code vvv  ############################################################################### | ||||||
|  | 
 | ||||||
|  |     private void getLocationPermission() { | ||||||
|  |         String[] permissions = {Manifest.permission.ACCESS_FINE_LOCATION}; | ||||||
|  |         if (ContextCompat.checkSelfPermission(this.getApplicationContext(), FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) { | ||||||
|  |             mLocationPermissionsGranted = true; | ||||||
|  |             initMap(); | ||||||
|  |         } else { | ||||||
|  |             ActivityCompat.requestPermissions(this, permissions, LOCATION_PERMISSION_REQUEST_CODE); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { | ||||||
|  |         super.onRequestPermissionsResult(requestCode, permissions, grantResults); | ||||||
|  |         mLocationPermissionsGranted = false; | ||||||
|  | 
 | ||||||
|  |         switch (requestCode) { | ||||||
|  |             case LOCATION_PERMISSION_REQUEST_CODE: { | ||||||
|  |                 if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { | ||||||
|  |                     mLocationPermissionsGranted = true; | ||||||
|  |                     initMap();      //initalize or map | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void initMap() { | ||||||
|  |         SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map); | ||||||
|  |         mapFragment.getMapAsync(this); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void onMapReady(GoogleMap googleMap) { | ||||||
|  |         Toast.makeText(this, "Map is ready", Toast.LENGTH_SHORT).show(); | ||||||
|  |         mMap = googleMap; | ||||||
|  | 
 | ||||||
|  |         if (mLocationPermissionsGranted) { | ||||||
|  |             getDeviceLocation(); | ||||||
|  | 
 | ||||||
|  |             if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) | ||||||
|  |                     != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, | ||||||
|  |                     Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             mMap.setMyLocationEnabled(true); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // Add a marker in Sydney and move the camera | ||||||
|  |         //LatLng sydney = new LatLng(-34, 151); | ||||||
|  |         //mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney")); | ||||||
|  |         //mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void getDeviceLocation(){ | ||||||
|  |         mFusedLocationProviderClient = LocationServices.getFusedLocationProviderClient(this); | ||||||
|  |         try { | ||||||
|  |             if (mLocationPermissionsGranted){ | ||||||
|  |                 final Task location = mFusedLocationProviderClient.getLastLocation(); | ||||||
|  | 
 | ||||||
|  |                 location.addOnCompleteListener(new OnCompleteListener() { | ||||||
|  | 
 | ||||||
|  |                     @Override | ||||||
|  |                     public void onComplete(@NonNull Task task) { | ||||||
|  |                         if (task.isSuccessful()){ | ||||||
|  |                             currentLocation = (Location) task.getResult(); | ||||||
|  |                             //currentTime = Calendar.getInstance().getTimeInMillis();                                           //verschoben in setDataBaseValues | ||||||
|  |                             //Toast.makeText(EarthquakeMapsActivity.this, currentTime.toString(), Toast.LENGTH_SHORT).show();   //verschoben in setDataBaseValues | ||||||
|  |                             if(useOwnGPS) | ||||||
|  |                             { | ||||||
|  |                                 breitengrad = currentLocation.getLatitude(); | ||||||
|  |                                 laengengrad = currentLocation.getLongitude(); | ||||||
|  |                             } | ||||||
|  |                             currentLocation.setLatitude(breitengrad); | ||||||
|  |                             currentLocation.setLongitude(laengengrad); | ||||||
|  |                             moveCamera(new LatLng(currentLocation.getLatitude(), currentLocation.getLongitude()),15f); | ||||||
|  |                             //setDataBaseValues();      //Wurde verschoben zu Methode writeEarthquakeToDatabase | ||||||
|  |                         } | ||||||
|  |                         else{ | ||||||
|  |                             Toast.makeText(EarthquakeMapsActivity.this, "Current Location unavailable", Toast.LENGTH_SHORT).show(); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 }); | ||||||
|  |             } | ||||||
|  |         }catch (SecurityException e){ | ||||||
|  |             Log.e(TAG,"Device Location not found" + e.getMessage()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void moveCamera(LatLng latlng, float zoom){ | ||||||
|  |         Log.d(TAG,"Latitude: "+latlng.latitude+"Longitude: "+latlng.longitude); | ||||||
|  |         mMap.moveCamera(CameraUpdateFactory.newLatLngZoom(latlng, zoom)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     //##################################################################  ^^^^ GPS Code ^^^^  ############################################################################# | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  | 
 | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  |     //##################################################################  vvv Datenbank Code vvv  ######################################################################### | ||||||
|  | 
 | ||||||
|  |     public void getDataBaseValuesNoListener() | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").get().addOnCompleteListener(new OnCompleteListener<DataSnapshot>() { | ||||||
|  |             @Override | ||||||
|  |             public void onComplete(@NonNull Task<DataSnapshot> task) { | ||||||
|  |                 if (!task.isSuccessful()) { | ||||||
|  |                     System.out.println("Datenbankfehler in getDataBaseValuesNoListener"); | ||||||
|  |                     System.out.println("Error getting data: " + task.getException()); | ||||||
|  |                 } | ||||||
|  |                 else { | ||||||
|  |                     processDataBaseValues(task.getResult()); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void processDataBaseValues (DataSnapshot data) | ||||||
|  |     { | ||||||
|  |         processDeviceIndex(data); | ||||||
|  |         processLocation(data); | ||||||
|  |         //processMessageDisplay(data); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void processDeviceIndex(DataSnapshot data) | ||||||
|  |     { | ||||||
|  |         for (int i = 1; i<=4; i++) | ||||||
|  |         { | ||||||
|  |             String androidid = data.child("IDG" + i).child("androidid").getValue().toString(); | ||||||
|  |             if(androidid.isEmpty()) | ||||||
|  |             { | ||||||
|  |                 indexID = i; | ||||||
|  |                 break; | ||||||
|  |             }else | ||||||
|  |             { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void processLocation(DataSnapshot data) | ||||||
|  |     { | ||||||
|  |         String breitengradString = data.child("IDG" + indexID).child("breitengrad").getValue().toString(); | ||||||
|  |         String laengengradString = data.child("IDG" + indexID).child("laengengrad").getValue().toString(); | ||||||
|  | 
 | ||||||
|  |         if(breitengradString.isEmpty() || laengengradString.isEmpty()) | ||||||
|  |         { | ||||||
|  |             useOwnGPS = true; | ||||||
|  |         }else{ | ||||||
|  |             useOwnGPS = false; | ||||||
|  |             breitengrad = Double.parseDouble(breitengradString); | ||||||
|  |             laengengrad = Double.parseDouble(laengengradString); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     public void processMessageDisplay(DataSnapshot data) | ||||||
|  |     { | ||||||
|  |         String vibrationString; | ||||||
|  |         String androidid; | ||||||
|  |         for (int i = 1; i<=4; i++) | ||||||
|  |         { | ||||||
|  |             androidid = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("androidid").getValue().toString(); | ||||||
|  |             vibrationString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("vibration").getValue().toString(); | ||||||
|  |             if((!androidid.isEmpty()) && vibrationString.equals("true")) | ||||||
|  |             { | ||||||
|  |                 allowShakeEvent = false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |      */ | ||||||
|  | 
 | ||||||
|  |     public String getandroidid () | ||||||
|  |     { | ||||||
|  |         return Settings.Secure.getString(this.getContentResolver(), Settings.Secure.ANDROID_ID); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getDeviceIpAdress () | ||||||
|  |     { | ||||||
|  |         WifiManager wm = (WifiManager) getApplicationContext().getSystemService(WIFI_SERVICE); | ||||||
|  |         int ip = wm.getConnectionInfo().getIpAddress(); | ||||||
|  |         String ipAddress = String.format("%d.%d.%d.%d",(ip & 0xff),(ip >> 8 & 0xff),(ip >> 16 & 0xff), (ip >> 24 & 0xff)); | ||||||
|  |         return ipAddress; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setDataBaseValues() | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + indexID).child("ip").setValue(getDeviceIpAdress()); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + indexID).child("vibration").setValue(true); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + indexID).child("timestamp").setValue(Calendar.getInstance().getTimeInMillis()); | ||||||
|  | 
 | ||||||
|  |         currentTime = Calendar.getInstance().getTimeInMillis(); | ||||||
|  |         Toast.makeText(EarthquakeMapsActivity.this, currentTime.toString(), Toast.LENGTH_SHORT).show(); | ||||||
|  | 
 | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + indexID).child("breitengrad").setValue(breitengrad); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + indexID).child("laengengrad").setValue(laengengrad); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + indexID).child("amplitude").setValue(1001); | ||||||
|  |         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + indexID).child("localdatetime").setValue(LocalDateTime.now().toString()); | ||||||
|  |         } | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + indexID).child("androidid").setValue(getandroidid()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     //##################################################################  ^^^^ Datenbank Code ^^^^  ############################################################################# | ||||||
|  |     //########################################################################################################################################################################### | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //Evtl. Redundanter Code | ||||||
|  | /* | ||||||
|  |     public void getDataBaseValues() | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         mDatenbank.addValueEventListener(new ValueEventListener() { | ||||||
|  |             @Override | ||||||
|  |             public void onDataChange(@NonNull DataSnapshot snapshot) { | ||||||
|  |                 processDataBaseValues(snapshot);                           //Daten Snapshot, Übergabe an processDataBaseValues | ||||||
|  |             } | ||||||
|  |             @Override | ||||||
|  |             public void onCancelled(@NonNull DatabaseError error) { | ||||||
|  |                 getDataBaseFailure(error); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void getDataBaseFailure (DatabaseError error) | ||||||
|  |     { | ||||||
|  |         System.out.println("Datenbankfehler in gerDataBaseFailure"); | ||||||
|  |         Log.w("Datenbankfehler", error.toException()); | ||||||
|  |     } | ||||||
|  |  */ | ||||||
							
								
								
									
										263
									
								
								app/src/main/java/de/edotzlaff/schockwelle/MainActivity.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,263 @@ | |||||||
|  | package de.edotzlaff.schockwelle; | ||||||
|  | 
 | ||||||
|  | import androidx.annotation.NonNull; | ||||||
|  | import androidx.annotation.RequiresApi; | ||||||
|  | import androidx.appcompat.app.AppCompatActivity; | ||||||
|  | import androidx.fragment.app.FragmentActivity; | ||||||
|  | 
 | ||||||
|  | import android.app.ActionBar; | ||||||
|  | import android.app.Dialog; | ||||||
|  | import android.content.Intent; | ||||||
|  | import android.hardware.Sensor; | ||||||
|  | import android.os.Build; | ||||||
|  | import android.os.Bundle; | ||||||
|  | import android.provider.Settings; | ||||||
|  | import android.util.Log; | ||||||
|  | import android.view.View; | ||||||
|  | import android.widget.Button; | ||||||
|  | import android.widget.Toast; | ||||||
|  | 
 | ||||||
|  | import com.google.android.gms.common.ConnectionResult; | ||||||
|  | import com.google.android.gms.common.GoogleApiAvailability; | ||||||
|  | import com.google.android.gms.tasks.OnCompleteListener; | ||||||
|  | import com.google.android.gms.tasks.Task; | ||||||
|  | import com.google.firebase.database.DataSnapshot; | ||||||
|  | import com.google.firebase.database.DatabaseError; | ||||||
|  | import com.google.firebase.database.DatabaseReference; | ||||||
|  | import com.google.firebase.database.FirebaseDatabase; | ||||||
|  | import com.google.firebase.database.ValueEventListener; | ||||||
|  | 
 | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  | import java.time.format.DateTimeFormatter; | ||||||
|  | import java.util.Calendar; | ||||||
|  | 
 | ||||||
|  | public class MainActivity extends FragmentActivity { | ||||||
|  | 
 | ||||||
|  |     private static final String TAG = "MainActivity"; | ||||||
|  |     private static final int ERROR_DIALOG_REQUEST = 9001; | ||||||
|  |     private DatabaseReference mDatenbank; | ||||||
|  |     String android_id; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     protected void onCreate(Bundle savedInstanceState) { | ||||||
|  |         super.onCreate(savedInstanceState); | ||||||
|  |         setContentView(R.layout.activity_main); | ||||||
|  | 
 | ||||||
|  |         if (isServiceOK()){ | ||||||
|  |             init(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void init(){ | ||||||
|  | 
 | ||||||
|  |         Button btnEarthquake = (Button) findViewById(R.id.btnEarthquake); | ||||||
|  |         Button btnSensor = (Button) findViewById(R.id.btnSensor); | ||||||
|  |         Button btnMuster = (Button) findViewById(R.id.buttonDatenBankMuster); | ||||||
|  |         Button btnLeer = (Button) findViewById(R.id.buttonDatenBankLeeren); | ||||||
|  |         Button btnReset = (Button) findViewById(R.id.buttonReset); | ||||||
|  | 
 | ||||||
|  |         btnEarthquake.setEnabled(false); | ||||||
|  |         btnEarthquake.setOnClickListener(new View.OnClickListener() { | ||||||
|  |             @Override | ||||||
|  |             public void onClick(View v) { | ||||||
|  |                 Intent intent = new Intent(MainActivity.this, EarthquakeMapsActivity.class); | ||||||
|  |                 btnEarthquake.setEnabled(false); | ||||||
|  |                 btnSensor.setEnabled(false); | ||||||
|  |                 startActivity(intent); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |         btnSensor.setEnabled(false); | ||||||
|  |         btnSensor.setOnClickListener(new View.OnClickListener() { | ||||||
|  |             @Override | ||||||
|  |             public void onClick(View v) { | ||||||
|  |                 Intent intent = new Intent(MainActivity.this, SensorMapsActivity.class); | ||||||
|  |                 btnSensor.setEnabled(false); | ||||||
|  |                 btnEarthquake.setEnabled(false); | ||||||
|  |                 startActivity(intent); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |         btnMuster.setOnClickListener(new View.OnClickListener() { | ||||||
|  |             @Override | ||||||
|  |             public void onClick(View v) { | ||||||
|  |                 btnEarthquake.setEnabled(true); | ||||||
|  |                 btnSensor.setEnabled(true); | ||||||
|  |                 btnLeer.setEnabled(false); | ||||||
|  |                 btnMuster.setEnabled(false); | ||||||
|  |                 btnReset.setEnabled(true); | ||||||
|  |                 deviceInitDataBase(); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |         btnLeer.setOnClickListener(new View.OnClickListener() { | ||||||
|  |             @Override | ||||||
|  |             public void onClick(View v) { | ||||||
|  |                 btnEarthquake.setEnabled(true); | ||||||
|  |                 btnSensor.setEnabled(true); | ||||||
|  |                 btnMuster.setEnabled(false); | ||||||
|  |                 btnReset.setEnabled(true); | ||||||
|  |                 btnLeer.setEnabled(false); | ||||||
|  |                 datenBankLeeren(); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |         btnReset.setEnabled(false); | ||||||
|  |         btnReset.setOnClickListener(new View.OnClickListener() { | ||||||
|  |             @Override | ||||||
|  |             public void onClick(View v) { | ||||||
|  |                 getDataBaseValuesNoListener(); | ||||||
|  |                 btnEarthquake.setEnabled(true); | ||||||
|  |                 btnSensor.setEnabled(true); | ||||||
|  |                 btnMuster.setEnabled(true); | ||||||
|  |                 btnLeer.setEnabled(true); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public boolean isServiceOK(){ | ||||||
|  |         Log.d(TAG, "isServicesOK(): checking google services version"); | ||||||
|  | 
 | ||||||
|  |         int available = GoogleApiAvailability.getInstance().isGooglePlayServicesAvailable(MainActivity.this); | ||||||
|  | 
 | ||||||
|  |         if (available== ConnectionResult.SUCCESS){ | ||||||
|  |             Log.d(TAG,"isServicesOK: Google Play Services is working"); | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |         else if (GoogleApiAvailability.getInstance().isUserResolvableError(available)){ | ||||||
|  |             Log.d(TAG, "isServicesOK(): an error occured but we can fix it"); | ||||||
|  |             Dialog dialog = GoogleApiAvailability.getInstance().getErrorDialog(MainActivity.this, available, ERROR_DIALOG_REQUEST); | ||||||
|  |             dialog.show(); | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             Toast.makeText(this, "You can`t make map request", Toast.LENGTH_SHORT).show(); | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void deviceInitDataBase() | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         Devices d1 = new Devices("10.00.00.000", false, Calendar.getInstance().getTimeInMillis(), 52.51624237821577, 13.37683380067744, 1000, LocalDateTime.now().toString(), "");  //Berlin  52.51624237821577, 13.37683380067744 | ||||||
|  |         Devices d2 = new Devices("20.00.00.000", false, Calendar.getInstance().getTimeInMillis(), 48.7560280895443, 11.425157702952347, 200, LocalDateTime.now().toString(),"");     //Ingolstadt 48.7560280895443, 11.425157702952347 | ||||||
|  |         Devices d3 = new Devices("30.00.00.000", false, Calendar.getInstance().getTimeInMillis(), 48.16958655466396, 11.617418429524394, 30, LocalDateTime.now().toString(),"");    //München 48.16958655466396, 11.617418429524394 | ||||||
|  |         Devices d4 = new Devices("40.00.00.000", false, Calendar.getInstance().getTimeInMillis(), 45.55620112204013, 12.342516140205387, 4, LocalDateTime.now().toString(),"");   //Venedig 45.55620112204013, 12.342516140205387 | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG1").setValue(d1); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG2").setValue(d2); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG3").setValue(d3); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG4").setValue(d4); | ||||||
|  | 
 | ||||||
|  |         //Nürnberg HBF: 49.4474136331757, 11.082661293035727 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     //Datenbank auslesen OHNE Listener. D.h. es werden Daten (snapshot) ausgelesen und kein Listener hinterlegt. | ||||||
|  |     //Sollten sich danach Daten zu einem beliebigen Zeitpunkt in der DB ändern, wird die Funktion "onDataChange" NICHT erneut ausgelöst. | ||||||
|  |     public void getDataBaseValuesNoListener() | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").get().addOnCompleteListener(new OnCompleteListener<DataSnapshot>() { | ||||||
|  |             @Override | ||||||
|  |             public void onComplete(@NonNull Task<DataSnapshot> task) { | ||||||
|  |                 if (!task.isSuccessful()) { | ||||||
|  |                     System.out.println("Error getting data: " + task.getException()); | ||||||
|  |                 } | ||||||
|  |                 else { | ||||||
|  |                     testProcess(task.getResult()); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void datenBankLeeren() | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         for (int i = 1; i<=4; i++) | ||||||
|  |         { | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("ip").setValue(""); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("vibration").setValue(false); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("timestamp").setValue(""); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("breitengrad").setValue(""); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("laengengrad").setValue(""); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("amplitude").setValue(""); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("localdatetime").setValue(""); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("androidid").setValue(""); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void testProcess(DataSnapshot data) | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference().child("overviewAronTestetInDiesemAbschnitt"); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /* | ||||||
|  |     //Datenbank auslesen MIT Listener. D.h. es werden Daten (snapshot) ausgelesen und gleichzeitig ein Listener hinterlegt. | ||||||
|  |     //Sollten sich danach Daten zu einem beliebigen Zeitpunkt in der DB ändern, wird die Funktion "onDataChange" erneut ausgelöst und wieder Daten (snapshot) ausgelesen. | ||||||
|  |     public void getDataBaseValuesListener() | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         mDatenbank.addValueEventListener(new ValueEventListener() { | ||||||
|  |             @Override | ||||||
|  |             public void onDataChange(@NonNull DataSnapshot snapshot) { | ||||||
|  |                 //testProcess(snapshot);                           //Daten - Snapshot, Übergabe an Methode processDataBaseValues | ||||||
|  |             } | ||||||
|  |             @Override | ||||||
|  |             public void onCancelled(@NonNull DatabaseError error) { | ||||||
|  |                 getDataBaseFailure(error); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* | ||||||
|  |     public void getDataBaseFailure (DatabaseError error) | ||||||
|  |     { | ||||||
|  |         System.out.println("Fehler"); | ||||||
|  |         Log.w("Datenbankfehler", error.toException()); | ||||||
|  |     } | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* | ||||||
|  |     @RequiresApi(api = Build.VERSION_CODES.O) | ||||||
|  |     public void processDataBaseValues (DataSnapshot data) | ||||||
|  |     { | ||||||
|  |         for (int i = 1; i<=4; i++)  //Für alle IDG 1-4 werden Werte ausgegeben | ||||||
|  |         { | ||||||
|  |             //####### Auslesen für String-Werte #######: | ||||||
|  |             String ipAdresse = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("ip").getValue().toString(); | ||||||
|  | 
 | ||||||
|  |             //####### Auslesen für boolean-Werte #######: | ||||||
|  |             String vibrationString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("vibration").getValue().toString(); | ||||||
|  |             boolean vibration; | ||||||
|  |             if(vibrationString == "true"){ | ||||||
|  |                 vibration = true; | ||||||
|  |             }else{ | ||||||
|  |                 vibration = false; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             //####### Auslesen für double-Werte #######: | ||||||
|  |             String breitengradString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("breitengrad").getValue().toString(); | ||||||
|  |             String laengengradString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("laengengrad").getValue().toString(); | ||||||
|  |             double breitengrad = Double.parseDouble(breitengradString); | ||||||
|  |             double laengengrad = Double.parseDouble(laengengradString); | ||||||
|  | 
 | ||||||
|  |             //####### Auslesen für long-Werte #######: | ||||||
|  |             String timestampString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("timestamp").getValue().toString(); | ||||||
|  |             long timestamp = Long.parseLong(timestampString); | ||||||
|  | 
 | ||||||
|  |             //####### Auslesen für ing-Werte #######: | ||||||
|  |             String amplitudeString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("amplitude").getValue().toString(); | ||||||
|  |             int amplitude = Integer.parseInt(amplitudeString); | ||||||
|  | 
 | ||||||
|  |             //####### Auslesen für LocalDateTime#######: | ||||||
|  |             String localdatetimeString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("localdatetime").getValue().toString(); | ||||||
|  |             DateTimeFormatter formatter = DateTimeFormatter.ISO_DATE_TIME; | ||||||
|  |             LocalDateTime localdatetime = LocalDateTime.parse(localdatetimeString, formatter); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  */ | ||||||
| @ -0,0 +1,452 @@ | |||||||
|  | package de.edotzlaff.schockwelle; | ||||||
|  | 
 | ||||||
|  | import android.Manifest; | ||||||
|  | import android.content.Context; | ||||||
|  | import android.content.pm.PackageManager; | ||||||
|  | import android.location.Location; | ||||||
|  | import android.os.Build; | ||||||
|  | import android.os.Bundle; | ||||||
|  | import android.os.CountDownTimer; | ||||||
|  | import android.os.VibrationEffect; | ||||||
|  | import android.os.Vibrator; | ||||||
|  | import android.provider.Settings; | ||||||
|  | import android.util.Log; | ||||||
|  | import android.widget.TextView; | ||||||
|  | import android.widget.Toast; | ||||||
|  | 
 | ||||||
|  | import androidx.annotation.NonNull; | ||||||
|  | import androidx.core.app.ActivityCompat; | ||||||
|  | import androidx.core.content.ContextCompat; | ||||||
|  | import androidx.fragment.app.FragmentActivity; | ||||||
|  | 
 | ||||||
|  | import com.google.android.gms.location.FusedLocationProviderClient; | ||||||
|  | import com.google.android.gms.location.LocationServices; | ||||||
|  | import com.google.android.gms.maps.CameraUpdateFactory; | ||||||
|  | import com.google.android.gms.maps.GoogleMap; | ||||||
|  | import com.google.android.gms.maps.OnMapReadyCallback; | ||||||
|  | import com.google.android.gms.maps.SupportMapFragment; | ||||||
|  | import com.google.android.gms.maps.model.LatLng; | ||||||
|  | import com.google.android.gms.maps.model.MarkerOptions; | ||||||
|  | import com.google.android.gms.tasks.OnCompleteListener; | ||||||
|  | import com.google.android.gms.tasks.Task; | ||||||
|  | import com.google.firebase.database.DataSnapshot; | ||||||
|  | import com.google.firebase.database.DatabaseError; | ||||||
|  | import com.google.firebase.database.DatabaseReference; | ||||||
|  | import com.google.firebase.database.FirebaseDatabase; | ||||||
|  | import com.google.firebase.database.ValueEventListener; | ||||||
|  | 
 | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  | import java.util.Calendar; | ||||||
|  | import java.util.Date; | ||||||
|  | 
 | ||||||
|  | public class SensorMapsActivity extends FragmentActivity implements OnMapReadyCallback { | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     private static final String TAG = "MainActivity"; | ||||||
|  |     private static final String FINE_LOCATION = Manifest.permission.ACCESS_FINE_LOCATION; | ||||||
|  |     private static final int LOCATION_PERMISSION_REQUEST_CODE = 1234; | ||||||
|  |     private static final double EARTHQUAKE_VELOCITY = 1; // 1 Meter pro Sekunde Erdbebengeschwindigkeit | ||||||
|  | 
 | ||||||
|  |     //vars | ||||||
|  |     private Boolean mLocationPermissionsGranted = false; | ||||||
|  |     private GoogleMap mMap; | ||||||
|  |     private FusedLocationProviderClient mFusedLocationProviderClient; | ||||||
|  | 
 | ||||||
|  |     //Date currentTime; | ||||||
|  |     Location currentLocation; | ||||||
|  |     Long currentTime; | ||||||
|  | 
 | ||||||
|  |     private double breitengrad; | ||||||
|  |     private double laengengrad; | ||||||
|  |     private double sensorGPSbreitengrad; | ||||||
|  |     private double sensorGPSlaengengrad; | ||||||
|  |     private boolean useOwnGPS; | ||||||
|  |     private boolean takeGPSfromDB = true; | ||||||
|  |     private boolean tookOwnGPS = false; | ||||||
|  | 
 | ||||||
|  |     boolean vibrationTrigger = true; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     private DatabaseReference mDatenbank; | ||||||
|  |     private String breitengradQuellVibration; | ||||||
|  |     private String laengengradQuellVibration; | ||||||
|  | 
 | ||||||
|  |     private Boolean mDeviceCanVibrate = false; | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     protected void onCreate(Bundle savedInstanceState) { | ||||||
|  |         super.onCreate(savedInstanceState); | ||||||
|  |         setContentView(R.layout.activity_sensor_maps); | ||||||
|  | 
 | ||||||
|  |         getDataBaseValuesWithListener(); | ||||||
|  | 
 | ||||||
|  |         TextView tv= (TextView) findViewById(R.id.txtSensor); | ||||||
|  |         getLocationPermission(); //Zuerst werden die aktuellen Standortdaten ermittelt | ||||||
|  | 
 | ||||||
|  |         getVibrationAbility(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  |     //##################################################################  vvv ShakeCode vvv  ############################################################################## | ||||||
|  |     private void getVibrationAbility() | ||||||
|  |     { | ||||||
|  |         // Get instance of Vibrator from current Context | ||||||
|  |         Vibrator v = (Vibrator) getSystemService(Context.VIBRATOR_SERVICE); | ||||||
|  | 
 | ||||||
|  |         // Output yes if can vibrate, no otherwise | ||||||
|  |         if (v.hasVibrator()) { | ||||||
|  |             Log.v("Can Vibrate", "YES"); | ||||||
|  |             //     Log.v("Can Control Amplitude", v.hasAmplitudeControl() ? "YES" : "NO"); | ||||||
|  |             mDeviceCanVibrate = true; | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  | 
 | ||||||
|  |             Log.v("Can Vibrate", "NO"); | ||||||
|  |             mDeviceCanVibrate = false; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private long getTimeStampDifference(float distance) | ||||||
|  |     { | ||||||
|  |         long diff= 0; | ||||||
|  |         //TODO Zeitdifferenz in Millisekunden zwischen aktuellen Uhrzeit und Vibratonszeitstempel berechnen | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         if (distance>0) | ||||||
|  |         { | ||||||
|  |             diff = (long)Math.round(1/(EARTHQUAKE_VELOCITY/distance)); | ||||||
|  |         } | ||||||
|  |         return diff; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void setVibrationTimer(long msDelay, int duration, int amplitude, int index) | ||||||
|  |     { | ||||||
|  | 
 | ||||||
|  |         new CountDownTimer(msDelay, 1000) { | ||||||
|  |             public void onTick(long millisUntilFinished) { | ||||||
|  |                 ((TextView)   findViewById(R.id.txtSensor)).setText("Earthquake hits in " + millisUntilFinished / 1000 + " s"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             public void onFinish() { | ||||||
|  |                 Toast.makeText(getApplicationContext(), "The Ground is shaking!", Toast.LENGTH_SHORT).show(); | ||||||
|  |                 performVibration(duration, amplitude); | ||||||
|  |                 ( (TextView)   findViewById(R.id.txtSensor)).setText("No Earthquake upcoming"); | ||||||
|  |                 //In DB schreiben! | ||||||
|  |                 setVibrationInDataBase(index); | ||||||
|  |             } | ||||||
|  |         }.start(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void performVibration(int duration, int amplitude) { | ||||||
|  |         if(!mDeviceCanVibrate) | ||||||
|  |             return; | ||||||
|  | 
 | ||||||
|  |         Vibrator v = (Vibrator) getSystemService(Context.VIBRATOR_SERVICE); | ||||||
|  |         if (Build.VERSION.SDK_INT >= 26) { | ||||||
|  |             if(duration == 0) | ||||||
|  |             { | ||||||
|  |                 v.cancel(); //stop vibration if still running | ||||||
|  |                 Toast.makeText(this,  "Vibration has been stopped", Toast.LENGTH_SHORT).show(); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             Toast.makeText(this,  "Ampl: " + amplitude + ", Dur: " + duration, Toast.LENGTH_SHORT).show(); | ||||||
|  | 
 | ||||||
|  |             v.vibrate(VibrationEffect.createOneShot(duration,amplitude)); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         } else { | ||||||
|  | 
 | ||||||
|  |             if(duration == 0) | ||||||
|  |             { | ||||||
|  |                 v.cancel(); //stop vibration if still running | ||||||
|  | 
 | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             v.vibrate(duration); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     //##################################################################  ^^^^ ShakeCode ^^^^  ############################################################################ | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  | 
 | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  |     //##################################################################  vvv GPS Code vvv  ############################################################################### | ||||||
|  | 
 | ||||||
|  |     private void getLocationPermission() { | ||||||
|  |         String[] permissions = {Manifest.permission.ACCESS_FINE_LOCATION}; | ||||||
|  |         if (ContextCompat.checkSelfPermission(this.getApplicationContext(), FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) { | ||||||
|  |             mLocationPermissionsGranted = true; | ||||||
|  |             initMap(); | ||||||
|  |         } else { | ||||||
|  |             ActivityCompat.requestPermissions(this, permissions, LOCATION_PERMISSION_REQUEST_CODE); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { | ||||||
|  |         super.onRequestPermissionsResult(requestCode, permissions, grantResults); | ||||||
|  |         mLocationPermissionsGranted = false; | ||||||
|  | 
 | ||||||
|  |         switch (requestCode) { | ||||||
|  |             case LOCATION_PERMISSION_REQUEST_CODE: { | ||||||
|  |                 if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { | ||||||
|  |                     mLocationPermissionsGranted = true; | ||||||
|  |                     //initalize or map | ||||||
|  |                     initMap(); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     void initMap(){ | ||||||
|  |         // Obtain the SupportMapFragment and get notified when the map is ready to be used. | ||||||
|  |         SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager() | ||||||
|  |                 .findFragmentById(R.id.map); | ||||||
|  |         mapFragment.getMapAsync(this); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void onMapReady(GoogleMap googleMap) { | ||||||
|  | 
 | ||||||
|  |         Toast.makeText(this, "Map is ready", Toast.LENGTH_SHORT).show(); | ||||||
|  |         mMap = googleMap; | ||||||
|  | 
 | ||||||
|  |         if (mLocationPermissionsGranted) { | ||||||
|  |             getDeviceLocation(); | ||||||
|  | 
 | ||||||
|  |             if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) | ||||||
|  |                     != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, | ||||||
|  |                     Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) { | ||||||
|  | 
 | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             mMap.setMyLocationEnabled(true); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // Add a marker in Sydney and move the camera | ||||||
|  |         //LatLng sydney = new LatLng(-34, 151); | ||||||
|  |         //mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney")); | ||||||
|  |         //mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void getDeviceLocation(){ | ||||||
|  |         mFusedLocationProviderClient = LocationServices.getFusedLocationProviderClient(this); | ||||||
|  |         try { | ||||||
|  |             if (mLocationPermissionsGranted){ | ||||||
|  |                 final Task location = mFusedLocationProviderClient.getLastLocation(); | ||||||
|  | 
 | ||||||
|  |                 location.addOnCompleteListener(new OnCompleteListener() { | ||||||
|  | 
 | ||||||
|  |                     @Override | ||||||
|  |                     public void onComplete(@NonNull Task task) { | ||||||
|  |                         if (task.isSuccessful()){ | ||||||
|  |                             currentLocation = (Location) task.getResult(); | ||||||
|  |                             currentTime = Calendar.getInstance().getTimeInMillis(); | ||||||
|  |                             if (!useOwnGPS) | ||||||
|  |                             { | ||||||
|  |                                 currentLocation.setLatitude(breitengrad); | ||||||
|  |                                 currentLocation.setLongitude(laengengrad); | ||||||
|  |                             } | ||||||
|  |                             Toast.makeText(SensorMapsActivity.this, currentTime.toString(), Toast.LENGTH_SHORT).show(); | ||||||
|  |                             moveCamera(new LatLng(currentLocation.getLatitude(), currentLocation.getLongitude()),15f); | ||||||
|  |                         } | ||||||
|  |                         else{ | ||||||
|  |                             Toast.makeText(SensorMapsActivity.this, "Current Location unavailable", Toast.LENGTH_SHORT).show(); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 }); | ||||||
|  |             } | ||||||
|  |         }catch (SecurityException e){ | ||||||
|  |             Log.e(TAG,"Device Location not found" + e.getMessage()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void moveCamera(LatLng latlng, float zoom){ | ||||||
|  |         Log.d(TAG,"Latitude: "+latlng.latitude+"Longitude: "+latlng.longitude); | ||||||
|  |         mMap.moveCamera(CameraUpdateFactory.newLatLngZoom(latlng, zoom)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     //##################################################################  ^^^^ GPS Code ^^^^  ############################################################################# | ||||||
|  |     //##################################################################################################################################################################### | ||||||
|  | 
 | ||||||
|  |     //Datenbank auslesen mit Listener. D.h. es werden Daten (snapshot) ausgelesen und gleichzeitig ein Listener hinterlegt. | ||||||
|  |     //Sollten sich danach Daten zu einem beliebigen Zeitpunkt in der DB ändern, wird die Funktion "onDataChange" erneut ausgelöst und wieder Daten (snapshot) ausgelesen. | ||||||
|  |     public void getDataBaseValuesWithListener() | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         mDatenbank.addValueEventListener(new ValueEventListener() { | ||||||
|  |             @Override | ||||||
|  |             public void onDataChange(@NonNull DataSnapshot snapshot) { | ||||||
|  |                 processDataBaseUpdate(snapshot); | ||||||
|  |             } | ||||||
|  |             @Override | ||||||
|  |             public void onCancelled(@NonNull DatabaseError error) { | ||||||
|  |                 getDataBaseFailure(error); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void processDataBaseUpdate (DataSnapshot data) | ||||||
|  |     { | ||||||
|  |         String breitengradString; | ||||||
|  |         String laengengradString; | ||||||
|  |         String vibrationString; | ||||||
|  |         String androidid; | ||||||
|  |         int vibratingDevices = 0; | ||||||
|  | 
 | ||||||
|  |         for (int i = 1; i<=4; i++) | ||||||
|  |         { | ||||||
|  |             breitengradString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("breitengrad").getValue().toString(); | ||||||
|  |             laengengradString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("laengengrad").getValue().toString(); | ||||||
|  | 
 | ||||||
|  |             androidid = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("androidid").getValue().toString(); | ||||||
|  |             vibrationString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("vibration").getValue().toString(); | ||||||
|  | 
 | ||||||
|  |             if(!androidid.isEmpty()) | ||||||
|  |             { | ||||||
|  |                 //System.out.println("Index " + i + " ist nicht leer"); | ||||||
|  |                 if(vibrationString == "false") | ||||||
|  |                 { | ||||||
|  |                     //System.out.println("Index " + i + " Vibration ist false"); | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     //System.out.println("Index " + i + " Vibration ist true"); | ||||||
|  |                     if(androidid.equals(getandroidid())) | ||||||
|  |                     { | ||||||
|  |                         //System.out.println("Index " + i + " Vibration ist von mir. Falscher Alarm"); | ||||||
|  |                         vibrationTrigger = false; | ||||||
|  |                         break; | ||||||
|  |                     } | ||||||
|  |                     else | ||||||
|  |                     { | ||||||
|  |                         //System.out.println("Index " + i + " Vibration ist nicht von mir. Breitengrad und Laegengrad von Vibrationsquelle bestimmen."); | ||||||
|  |                         breitengradQuellVibration = breitengradString; | ||||||
|  |                         laengengradQuellVibration = laengengradString; | ||||||
|  |                         vibratingDevices++; | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 //System.out.println("Index " + i + " ist leer"); | ||||||
|  |                 if(androidid.isEmpty() && !breitengradString.isEmpty() && !laengengradString.isEmpty() && vibrationString.equals("false") && takeGPSfromDB) | ||||||
|  |                 { | ||||||
|  |                     System.out.println("Index " + i +" -> Leere AdnroidID. Breitengrad und Laengengrad sind belegt. Vibration ist false. Kann als eigenes Gerät beansprucht werden."); | ||||||
|  |                     System.out.println("Index " + i +" -> Übernehme Breitengrad: " + breitengradString + " und Laengengrad: " + laengengradString + " als eigene Position."); | ||||||
|  |                     breitengrad = Double.parseDouble(breitengradString); | ||||||
|  |                     laengengrad = Double.parseDouble(laengengradString); | ||||||
|  |                     useOwnGPS = false; | ||||||
|  |                     takeGPSfromDB = false; | ||||||
|  |                 }else | ||||||
|  |                 { | ||||||
|  |                     if(!tookOwnGPS && takeGPSfromDB) | ||||||
|  |                     { | ||||||
|  |                         //System.out.println("Nutze eigene DB. Bin bei Index " + i + " ++++++++++++++++++++++++++++++++++++++++++++"); | ||||||
|  |                         tookOwnGPS = true; | ||||||
|  |                         useOwnGPS = true; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 if(vibrationTrigger == true && (vibratingDevices == 1)) | ||||||
|  |                 { | ||||||
|  |                     //System.out.println("#########Freigabe zum Schreiben in DB mit Index " + i + " liegt vor. Schreibe nun... !!!!!#####################"); | ||||||
|  |                     /* | ||||||
|  |                     System.out.println("currentLocation.getLatitude():                 " + currentLocation.getLatitude()); | ||||||
|  |                     System.out.println("currentLocation.getLongitude():                " + currentLocation.getLongitude()); | ||||||
|  |                     System.out.println("Double.parseDouble(breitengradQuellVibration): " + Double.parseDouble(breitengradQuellVibration)); | ||||||
|  |                     System.out.println("Double.parseDouble(laengengradQuellVibration): " + Double.parseDouble(laengengradQuellVibration)); | ||||||
|  |                     System.out.println("######################################################################################################################################################################"); | ||||||
|  |                      */ | ||||||
|  | 
 | ||||||
|  |                     vibrationTrigger = false; | ||||||
|  |                     float distanceToEarthquake; | ||||||
|  |                     distanceToEarthquake = distance(currentLocation.getLatitude(), currentLocation.getLongitude(), Double.parseDouble(breitengradQuellVibration), Double.parseDouble(laengengradQuellVibration)); | ||||||
|  |                     System.out.println("Distance to Earthquake: " + distanceToEarthquake); | ||||||
|  |                     long wellenAusbreitungsGeschwindigkeit = 4500;    //Meter die Sekunde | ||||||
|  |                     long delayInSeconds = (long) distanceToEarthquake/wellenAusbreitungsGeschwindigkeit; //s | ||||||
|  |                     long delayInMilliSeconds = delayInSeconds*1000; | ||||||
|  |                     setVibrationTimer(delayInMilliSeconds,1500,255,i); | ||||||
|  |                     //setVibrationInDataBase(i); | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         //TODO Weiterer Code von Patrick. @Aron Anschauen ob dieser noch verwendet werden muss da paar Sachen schon in dieser Version umgesetzt worde sind. | ||||||
|  |         /* | ||||||
|  |         //####### Auslesen für boolean-Werte #######: | ||||||
|  |         int i = 1; | ||||||
|  |         String vibrationString = data.child("overview").child("IDG").child("vibration").getValue().toString(); | ||||||
|  |         String amplitudeString = data.child("overview").child("IDG").child("amplitude").getValue().toString(); | ||||||
|  |         boolean vibration; | ||||||
|  |         if(vibrationString.equals("true")){ | ||||||
|  |             vibration = true; | ||||||
|  |         }else{ | ||||||
|  |             vibration = false; | ||||||
|  |         } | ||||||
|  |         int amplitude = Integer.parseInt(amplitudeString); | ||||||
|  |         // Workaround beseiteigen: hier wird immer davon ausgegangen, dass auslösendes Gerät die ID 1 besitzt | ||||||
|  |         if(vibration == true && i == 1) | ||||||
|  |         { | ||||||
|  |             float distance = distance(currentLocation.getLatitude(), currentLocation.getLongitude(),breitengrad,laengengrad); | ||||||
|  |             long delay = getTimeStampDifference(distance); | ||||||
|  |             setVibrationTimer(delay,1000,amplitude); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |          */ | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setVibrationInDataBase(int k) | ||||||
|  |     { | ||||||
|  |         mDatenbank = FirebaseDatabase.getInstance().getReference(); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("ip").setValue(k + "0.00.00.000"); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("vibration").setValue(true); | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("timestamp").setValue(Calendar.getInstance().getTimeInMillis());     //aktueller Zeitstempel wird in Datenbank eingetragen | ||||||
|  | 
 | ||||||
|  |         if (useOwnGPS) | ||||||
|  |         { | ||||||
|  |             //System.out.println("YYYcurrentLocation.getLatitude():                 " + currentLocation.getLatitude()); | ||||||
|  |             //System.out.println("YYYcurrentLocation.getLongitude():                " + currentLocation.getLongitude()); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("breitengrad").setValue(currentLocation.getLatitude());    //aktueller Breitengrad | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("laengengrad").setValue(currentLocation.getLongitude());   //aktueller Längergrad | ||||||
|  |         }else{ | ||||||
|  |             //System.out.println("YYYbreitengrad:                 " + breitengrad); | ||||||
|  |             //System.out.println("YYYlaengengrad:                 " + laengengrad); | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("breitengrad").setValue(breitengrad);    //aktueller Breitengrad | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("laengengrad").setValue(laengengrad);   //aktueller Längergrad | ||||||
|  |         } | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("amplitude").setValue(1001); | ||||||
|  |         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { | ||||||
|  |             mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("localdatetime").setValue(LocalDateTime.now().toString()); | ||||||
|  |         } | ||||||
|  |         mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + k).child("androidid").setValue(getandroidid()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getandroidid () | ||||||
|  |     { | ||||||
|  |         return Settings.Secure.getString(this.getContentResolver(), Settings.Secure.ANDROID_ID); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void getDataBaseFailure (DatabaseError error) | ||||||
|  |     { | ||||||
|  |         System.out.println("Fehler"); | ||||||
|  |         Log.w("Datenbankfehler", error.toException()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     //TODO Edward Dauer für Timer berechnen bis Smartphone vibriert | ||||||
|  | 
 | ||||||
|  |     private float distance(double currentlatitude, double currentlongitude, double originLat, double originLon) { | ||||||
|  | 
 | ||||||
|  |         float[] results = new float[1]; | ||||||
|  |         Location.distanceBetween(currentlatitude, currentlongitude, originLat, originLon, results); | ||||||
|  |         float distanceInMeters = results[0]; | ||||||
|  | 
 | ||||||
|  |         return distanceInMeters; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										30
									
								
								app/src/main/res/drawable-v24/ic_launcher_foreground.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,30 @@ | |||||||
|  | <vector xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     xmlns:aapt="http://schemas.android.com/aapt" | ||||||
|  |     android:width="108dp" | ||||||
|  |     android:height="108dp" | ||||||
|  |     android:viewportWidth="108" | ||||||
|  |     android:viewportHeight="108"> | ||||||
|  |     <path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z"> | ||||||
|  |         <aapt:attr name="android:fillColor"> | ||||||
|  |             <gradient | ||||||
|  |                 android:endX="85.84757" | ||||||
|  |                 android:endY="92.4963" | ||||||
|  |                 android:startX="42.9492" | ||||||
|  |                 android:startY="49.59793" | ||||||
|  |                 android:type="linear"> | ||||||
|  |                 <item | ||||||
|  |                     android:color="#44000000" | ||||||
|  |                     android:offset="0.0" /> | ||||||
|  |                 <item | ||||||
|  |                     android:color="#00000000" | ||||||
|  |                     android:offset="1.0" /> | ||||||
|  |             </gradient> | ||||||
|  |         </aapt:attr> | ||||||
|  |     </path> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#FFFFFF" | ||||||
|  |         android:fillType="nonZero" | ||||||
|  |         android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z" | ||||||
|  |         android:strokeWidth="1" | ||||||
|  |         android:strokeColor="#00000000" /> | ||||||
|  | </vector> | ||||||
							
								
								
									
										170
									
								
								app/src/main/res/drawable/ic_launcher_background.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,170 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <vector xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     android:width="108dp" | ||||||
|  |     android:height="108dp" | ||||||
|  |     android:viewportWidth="108" | ||||||
|  |     android:viewportHeight="108"> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#3DDC84" | ||||||
|  |         android:pathData="M0,0h108v108h-108z" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M9,0L9,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M19,0L19,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M29,0L29,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M39,0L39,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M49,0L49,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M59,0L59,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M69,0L69,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M79,0L79,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M89,0L89,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M99,0L99,108" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,9L108,9" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,19L108,19" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,29L108,29" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,39L108,39" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,49L108,49" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,59L108,59" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,69L108,69" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,79L108,79" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,89L108,89" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M0,99L108,99" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M19,29L89,29" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M19,39L89,39" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M19,49L89,49" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M19,59L89,59" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M19,69L89,69" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M19,79L89,79" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M29,19L29,89" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M39,19L39,89" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M49,19L49,89" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M59,19L59,89" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M69,19L69,89" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  |     <path | ||||||
|  |         android:fillColor="#00000000" | ||||||
|  |         android:pathData="M79,19L79,89" | ||||||
|  |         android:strokeWidth="0.8" | ||||||
|  |         android:strokeColor="#33FFFFFF" /> | ||||||
|  | </vector> | ||||||
							
								
								
									
										28
									
								
								app/src/main/res/layout/activity_earthquake_maps.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,28 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <RelativeLayout 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=".EarthquakeMapsActivity" | ||||||
|  |     android:paddingTop="?attr/actionBarSize"> | ||||||
|  | 
 | ||||||
|  |     <TextView | ||||||
|  |         android:layout_width="wrap_content" | ||||||
|  |         android:layout_height="wrap_content" | ||||||
|  |         android:text="@string/shake_your_smartphone_for_a_earthquake" | ||||||
|  |         android:layout_centerHorizontal="true" | ||||||
|  |         android:id="@+id/txtEarthquake"/> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | <androidx.fragment.app.FragmentContainerView xmlns:map="http://schemas.android.com/apk/res-auto" | ||||||
|  |     android:layout_below="@+id/txtEarthquake" | ||||||
|  |     android:id="@+id/map" | ||||||
|  |     android:name="com.google.android.gms.maps.SupportMapFragment" | ||||||
|  |     android:layout_width="match_parent" | ||||||
|  |     android:layout_height="match_parent" | ||||||
|  |     android:layout_marginTop="50dp" | ||||||
|  | 
 | ||||||
|  |     tools:context=".EarthquakeMapsActivity" /> | ||||||
|  | 
 | ||||||
|  | </RelativeLayout> | ||||||
							
								
								
									
										52
									
								
								app/src/main/res/layout/activity_main.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,52 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <RelativeLayout 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"> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     <Button | ||||||
|  |         android:layout_width="wrap_content" | ||||||
|  |         android:layout_height="wrap_content" | ||||||
|  |         android:id="@+id/btnEarthquake" | ||||||
|  |         android:text="@string/generate_earthquake" | ||||||
|  |         android:layout_centerVertical="true" | ||||||
|  |         android:layout_centerHorizontal="true" /> | ||||||
|  | 
 | ||||||
|  |     <Button | ||||||
|  |         android:layout_width="wrap_content" | ||||||
|  |         android:layout_height="wrap_content" | ||||||
|  |         android:id="@+id/btnSensor" | ||||||
|  |         android:text="@string/be_a_sensor" | ||||||
|  |         android:layout_centerHorizontal="true" | ||||||
|  |         android:layout_below="@id/btnEarthquake"/> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     <Button | ||||||
|  |         android:id="@+id/buttonDatenBankMuster" | ||||||
|  |         android:layout_width="wrap_content" | ||||||
|  |         android:layout_height="wrap_content" | ||||||
|  |         android:layout_below="@+id/btnSensor" | ||||||
|  |         android:layout_centerHorizontal="true" | ||||||
|  |         android:layout_marginTop="50dp" | ||||||
|  |         android:text="@string/start_mit_vordefinierter_db" /> | ||||||
|  | 
 | ||||||
|  |     <Button | ||||||
|  |         android:id="@+id/buttonDatenBankLeeren" | ||||||
|  |         android:layout_width="wrap_content" | ||||||
|  |         android:layout_height="wrap_content" | ||||||
|  |         android:layout_below="@+id/buttonDatenBankMuster" | ||||||
|  |         android:layout_centerHorizontal="true" | ||||||
|  |         android:text="@string/start_mit_leeren_db" /> | ||||||
|  | 
 | ||||||
|  |     <Button | ||||||
|  |         android:id="@+id/buttonReset" | ||||||
|  |         android:layout_width="wrap_content" | ||||||
|  |         android:layout_height="wrap_content" | ||||||
|  |         android:layout_below="@+id/buttonDatenBankLeeren" | ||||||
|  |         android:layout_centerHorizontal="true" | ||||||
|  |         android:text="@string/weitermachen_buttonreset" /> | ||||||
|  | 
 | ||||||
|  | </RelativeLayout> | ||||||
							
								
								
									
										27
									
								
								app/src/main/res/layout/activity_sensor_maps.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,27 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | 
 | ||||||
|  | <RelativeLayout 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=".EarthquakeMapsActivity"> | ||||||
|  | 
 | ||||||
|  |     <TextView | ||||||
|  |         android:layout_width="wrap_content" | ||||||
|  |         android:layout_height="wrap_content" | ||||||
|  |         android:text="Timer till vibration" | ||||||
|  |         android:layout_centerHorizontal="true" | ||||||
|  |         android:id="@+id/txtSensor"/> | ||||||
|  | 
 | ||||||
|  | <fragment xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     xmlns:map="http://schemas.android.com/apk/res-auto" | ||||||
|  |     xmlns:tools="http://schemas.android.com/tools" | ||||||
|  |     android:layout_below="@+id/txtSensor" | ||||||
|  |     android:id="@+id/map" | ||||||
|  |     android:name="com.google.android.gms.maps.SupportMapFragment" | ||||||
|  |     android:layout_width="match_parent" | ||||||
|  |     android:layout_height="match_parent" | ||||||
|  |     tools:context=".SensorMapsActivity" /> | ||||||
|  | 
 | ||||||
|  | </RelativeLayout> | ||||||
							
								
								
									
										5
									
								
								app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,5 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> | ||||||
|  |     <background android:drawable="@drawable/ic_launcher_background" /> | ||||||
|  |     <foreground android:drawable="@drawable/ic_launcher_foreground" /> | ||||||
|  | </adaptive-icon> | ||||||
							
								
								
									
										5
									
								
								app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,5 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> | ||||||
|  |     <background android:drawable="@drawable/ic_launcher_background" /> | ||||||
|  |     <foreground android:drawable="@drawable/ic_launcher_foreground" /> | ||||||
|  | </adaptive-icon> | ||||||
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-hdpi/ic_launcher.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.5 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-hdpi/ic_launcher_round.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 5.2 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-mdpi/ic_launcher.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.6 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-mdpi/ic_launcher_round.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-xhdpi/ic_launcher.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-xhdpi/ic_launcher_round.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 7.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-xxhdpi/ic_launcher.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 7.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 12 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-xxhdpi/schockicon.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 91 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 10 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 16 KiB | 
							
								
								
									
										16
									
								
								app/src/main/res/values-night/themes.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,16 @@ | |||||||
|  | <resources xmlns:tools="http://schemas.android.com/tools"> | ||||||
|  |     <!-- Base application theme. --> | ||||||
|  |     <style name="Theme.Schockwelle" parent="Theme.MaterialComponents.DayNight.DarkActionBar"> | ||||||
|  |         <!-- Primary brand color. --> | ||||||
|  |         <item name="colorPrimary">@color/purple_200</item> | ||||||
|  |         <item name="colorPrimaryVariant">@color/purple_700</item> | ||||||
|  |         <item name="colorOnPrimary">@color/black</item> | ||||||
|  |         <!-- Secondary brand color. --> | ||||||
|  |         <item name="colorSecondary">@color/teal_200</item> | ||||||
|  |         <item name="colorSecondaryVariant">@color/teal_200</item> | ||||||
|  |         <item name="colorOnSecondary">@color/black</item> | ||||||
|  |         <!-- Status bar color. --> | ||||||
|  |         <item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item> | ||||||
|  |         <!-- Customize your theme here. --> | ||||||
|  |     </style> | ||||||
|  | </resources> | ||||||
							
								
								
									
										10
									
								
								app/src/main/res/values/colors.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,10 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <resources> | ||||||
|  |     <color name="purple_200">#FFBB86FC</color> | ||||||
|  |     <color name="purple_500">#FF6200EE</color> | ||||||
|  |     <color name="purple_700">#FF3700B3</color> | ||||||
|  |     <color name="teal_200">#FF03DAC5</color> | ||||||
|  |     <color name="teal_700">#FF018786</color> | ||||||
|  |     <color name="black">#FF000000</color> | ||||||
|  |     <color name="white">#FFFFFFFF</color> | ||||||
|  | </resources> | ||||||
							
								
								
									
										17
									
								
								app/src/main/res/values/strings.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,17 @@ | |||||||
|  | <resources> | ||||||
|  |     <string name="app_name">Schockwelle</string> | ||||||
|  |     <string name="title_activity_earthquake_maps">Map</string> | ||||||
|  |     <string name="title_activity_sensor_maps">Map</string> | ||||||
|  |     <string name="be_a_sensor">Be a Sensor</string> | ||||||
|  |     <string name="generate_earthquake">Generate Earthquake</string> | ||||||
|  |     <string name="buttontest">ButtonTest</string> | ||||||
|  |     <string name="mit_leeren_db_starten">Mit leeren DB starten</string> | ||||||
|  |     <string name="mit_voller_db_starten_beispielwerte">Mit voller DB starten (Beispielwerte)</string> | ||||||
|  |     <string name="mit_voller_db_starten">Mit voller DB starten</string> | ||||||
|  |     <string name="universalertestbutton">UniversalerTestButton</string> | ||||||
|  |     <string name="weitermachen">Weitermachen</string> | ||||||
|  |     <string name="shake_your_smartphone_for_a_earthquake">Shake your Smartphone for a Earthquake</string> | ||||||
|  |     <string name="start_mit_vordefinierter_db">Start mit vordefinierter DB</string> | ||||||
|  |     <string name="start_mit_leeren_db">Start mit Leeren DB</string> | ||||||
|  |     <string name="weitermachen_buttonreset">Weitermachen - Buttonreset</string> | ||||||
|  | </resources> | ||||||
							
								
								
									
										16
									
								
								app/src/main/res/values/themes.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,16 @@ | |||||||
|  | <resources xmlns:tools="http://schemas.android.com/tools"> | ||||||
|  |     <!-- Base application theme. --> | ||||||
|  |     <style name="Theme.Schockwelle" parent="Theme.MaterialComponents.DayNight.DarkActionBar"> | ||||||
|  |         <!-- Primary brand color. --> | ||||||
|  |         <item name="colorPrimary">@color/purple_500</item> | ||||||
|  |         <item name="colorPrimaryVariant">@color/purple_700</item> | ||||||
|  |         <item name="colorOnPrimary">@color/white</item> | ||||||
|  |         <!-- Secondary brand color. --> | ||||||
|  |         <item name="colorSecondary">@color/teal_200</item> | ||||||
|  |         <item name="colorSecondaryVariant">@color/teal_700</item> | ||||||
|  |         <item name="colorOnSecondary">@color/black</item> | ||||||
|  |         <!-- Status bar color. --> | ||||||
|  |         <item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item> | ||||||
|  |         <!-- Customize your theme here. --> | ||||||
|  |     </style> | ||||||
|  | </resources> | ||||||
							
								
								
									
										4
									
								
								app/src/release/res/values/google_maps_api.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,4 @@ | |||||||
|  | <resources> | ||||||
|  | 
 | ||||||
|  |     <string name="google_maps_key" templateMergeStrategy="preserve" translatable="false">YOUR_KEY_HERE</string> | ||||||
|  | </resources> | ||||||
| @ -0,0 +1,17 @@ | |||||||
|  | package de.edotzlaff.schockwelle; | ||||||
|  | 
 | ||||||
|  | import org.junit.Test; | ||||||
|  | 
 | ||||||
|  | import static org.junit.Assert.*; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Example local unit test, which will execute on the development machine (host). | ||||||
|  |  * | ||||||
|  |  * @see <a href="http://d.android.com/tools/testing">Testing documentation</a> | ||||||
|  |  */ | ||||||
|  | public class ExampleUnitTest { | ||||||
|  |     @Test | ||||||
|  |     public void addition_isCorrect() { | ||||||
|  |         assertEquals(4, 2 + 2); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										25
									
								
								build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,25 @@ | |||||||
|  | // Top-level build file where you can add configuration options common to all sub-projects/modules. | ||||||
|  | buildscript { | ||||||
|  |     repositories { | ||||||
|  |         google() | ||||||
|  |         jcenter() | ||||||
|  |     } | ||||||
|  |     dependencies { | ||||||
|  |         classpath 'com.android.tools.build:gradle:4.2.1' | ||||||
|  |         classpath 'com.google.gms:google-services:4.3.8' | ||||||
|  | 
 | ||||||
|  |         // NOTE: Do not place your application dependencies here; they belong | ||||||
|  |         // in the individual module build.gradle files | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | allprojects { | ||||||
|  |     repositories { | ||||||
|  |         google() | ||||||
|  |         jcenter() | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | task clean(type: Delete) { | ||||||
|  |     delete rootProject.buildDir | ||||||
|  | } | ||||||
							
								
								
									
										19
									
								
								gradle.properties
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,19 @@ | |||||||
|  | # Project-wide Gradle settings. | ||||||
|  | # IDE (e.g. Android Studio) users: | ||||||
|  | # Gradle settings configured through the IDE *will override* | ||||||
|  | # any settings specified in this file. | ||||||
|  | # For more details on how to configure your build environment visit | ||||||
|  | # http://www.gradle.org/docs/current/userguide/build_environment.html | ||||||
|  | # Specifies the JVM arguments used for the daemon process. | ||||||
|  | # The setting is particularly useful for tweaking memory settings. | ||||||
|  | org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8 | ||||||
|  | # When configured, Gradle will run in incubating parallel mode. | ||||||
|  | # This option should only be used with decoupled projects. More details, visit | ||||||
|  | # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects | ||||||
|  | # org.gradle.parallel=true | ||||||
|  | # AndroidX package structure to make it clearer which packages are bundled with the | ||||||
|  | # Android operating system, and which are packaged with your app"s APK | ||||||
|  | # https://developer.android.com/topic/libraries/support-library/androidx-rn | ||||||
|  | android.useAndroidX=true | ||||||
|  | # Automatically convert third-party libraries to use AndroidX | ||||||
|  | android.enableJetifier=true | ||||||
							
								
								
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										6
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,6 @@ | |||||||
|  | #Thu Jun 17 12:39:35 CEST 2021 | ||||||
|  | distributionBase=GRADLE_USER_HOME | ||||||
|  | distributionPath=wrapper/dists | ||||||
|  | zipStoreBase=GRADLE_USER_HOME | ||||||
|  | zipStorePath=wrapper/dists | ||||||
|  | distributionUrl=https\://services.gradle.org/distributions/gradle-6.7.1-all.zip | ||||||
							
								
								
									
										172
									
								
								gradlew
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,172 @@ | |||||||
|  | #!/usr/bin/env sh | ||||||
|  | 
 | ||||||
|  | ############################################################################## | ||||||
|  | ## | ||||||
|  | ##  Gradle start up script for UN*X | ||||||
|  | ## | ||||||
|  | ############################################################################## | ||||||
|  | 
 | ||||||
|  | # Attempt to set APP_HOME | ||||||
|  | # Resolve links: $0 may be a link | ||||||
|  | PRG="$0" | ||||||
|  | # Need this for relative symlinks. | ||||||
|  | while [ -h "$PRG" ] ; do | ||||||
|  |     ls=`ls -ld "$PRG"` | ||||||
|  |     link=`expr "$ls" : '.*-> \(.*\)$'` | ||||||
|  |     if expr "$link" : '/.*' > /dev/null; then | ||||||
|  |         PRG="$link" | ||||||
|  |     else | ||||||
|  |         PRG=`dirname "$PRG"`"/$link" | ||||||
|  |     fi | ||||||
|  | done | ||||||
|  | SAVED="`pwd`" | ||||||
|  | cd "`dirname \"$PRG\"`/" >/dev/null | ||||||
|  | APP_HOME="`pwd -P`" | ||||||
|  | cd "$SAVED" >/dev/null | ||||||
|  | 
 | ||||||
|  | APP_NAME="Gradle" | ||||||
|  | APP_BASE_NAME=`basename "$0"` | ||||||
|  | 
 | ||||||
|  | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | DEFAULT_JVM_OPTS="" | ||||||
|  | 
 | ||||||
|  | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||||||
|  | MAX_FD="maximum" | ||||||
|  | 
 | ||||||
|  | warn () { | ||||||
|  |     echo "$*" | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | die () { | ||||||
|  |     echo | ||||||
|  |     echo "$*" | ||||||
|  |     echo | ||||||
|  |     exit 1 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | # OS specific support (must be 'true' or 'false'). | ||||||
|  | cygwin=false | ||||||
|  | msys=false | ||||||
|  | darwin=false | ||||||
|  | nonstop=false | ||||||
|  | case "`uname`" in | ||||||
|  |   CYGWIN* ) | ||||||
|  |     cygwin=true | ||||||
|  |     ;; | ||||||
|  |   Darwin* ) | ||||||
|  |     darwin=true | ||||||
|  |     ;; | ||||||
|  |   MINGW* ) | ||||||
|  |     msys=true | ||||||
|  |     ;; | ||||||
|  |   NONSTOP* ) | ||||||
|  |     nonstop=true | ||||||
|  |     ;; | ||||||
|  | esac | ||||||
|  | 
 | ||||||
|  | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||||||
|  | 
 | ||||||
|  | # Determine the Java command to use to start the JVM. | ||||||
|  | if [ -n "$JAVA_HOME" ] ; then | ||||||
|  |     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||||||
|  |         # IBM's JDK on AIX uses strange locations for the executables | ||||||
|  |         JAVACMD="$JAVA_HOME/jre/sh/java" | ||||||
|  |     else | ||||||
|  |         JAVACMD="$JAVA_HOME/bin/java" | ||||||
|  |     fi | ||||||
|  |     if [ ! -x "$JAVACMD" ] ; then | ||||||
|  |         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||||||
|  | 
 | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  |     fi | ||||||
|  | else | ||||||
|  |     JAVACMD="java" | ||||||
|  |     which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  | 
 | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # Increase the maximum file descriptors if we can. | ||||||
|  | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then | ||||||
|  |     MAX_FD_LIMIT=`ulimit -H -n` | ||||||
|  |     if [ $? -eq 0 ] ; then | ||||||
|  |         if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then | ||||||
|  |             MAX_FD="$MAX_FD_LIMIT" | ||||||
|  |         fi | ||||||
|  |         ulimit -n $MAX_FD | ||||||
|  |         if [ $? -ne 0 ] ; then | ||||||
|  |             warn "Could not set maximum file descriptor limit: $MAX_FD" | ||||||
|  |         fi | ||||||
|  |     else | ||||||
|  |         warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" | ||||||
|  |     fi | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # For Darwin, add options to specify how the application appears in the dock | ||||||
|  | if $darwin; then | ||||||
|  |     GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # For Cygwin, switch paths to Windows format before running java | ||||||
|  | if $cygwin ; then | ||||||
|  |     APP_HOME=`cygpath --path --mixed "$APP_HOME"` | ||||||
|  |     CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` | ||||||
|  |     JAVACMD=`cygpath --unix "$JAVACMD"` | ||||||
|  | 
 | ||||||
|  |     # We build the pattern for arguments to be converted via cygpath | ||||||
|  |     ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` | ||||||
|  |     SEP="" | ||||||
|  |     for dir in $ROOTDIRSRAW ; do | ||||||
|  |         ROOTDIRS="$ROOTDIRS$SEP$dir" | ||||||
|  |         SEP="|" | ||||||
|  |     done | ||||||
|  |     OURCYGPATTERN="(^($ROOTDIRS))" | ||||||
|  |     # Add a user-defined pattern to the cygpath arguments | ||||||
|  |     if [ "$GRADLE_CYGPATTERN" != "" ] ; then | ||||||
|  |         OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" | ||||||
|  |     fi | ||||||
|  |     # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||||||
|  |     i=0 | ||||||
|  |     for arg in "$@" ; do | ||||||
|  |         CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` | ||||||
|  |         CHECK2=`echo "$arg"|egrep -c "^-"`                                 ### Determine if an option | ||||||
|  | 
 | ||||||
|  |         if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition | ||||||
|  |             eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` | ||||||
|  |         else | ||||||
|  |             eval `echo args$i`="\"$arg\"" | ||||||
|  |         fi | ||||||
|  |         i=$((i+1)) | ||||||
|  |     done | ||||||
|  |     case $i in | ||||||
|  |         (0) set -- ;; | ||||||
|  |         (1) set -- "$args0" ;; | ||||||
|  |         (2) set -- "$args0" "$args1" ;; | ||||||
|  |         (3) set -- "$args0" "$args1" "$args2" ;; | ||||||
|  |         (4) set -- "$args0" "$args1" "$args2" "$args3" ;; | ||||||
|  |         (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; | ||||||
|  |         (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; | ||||||
|  |         (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; | ||||||
|  |         (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; | ||||||
|  |         (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; | ||||||
|  |     esac | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # Escape application args | ||||||
|  | save () { | ||||||
|  |     for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done | ||||||
|  |     echo " " | ||||||
|  | } | ||||||
|  | APP_ARGS=$(save "$@") | ||||||
|  | 
 | ||||||
|  | # Collect all arguments for the java command, following the shell quoting and substitution rules | ||||||
|  | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" | ||||||
|  | 
 | ||||||
|  | # by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong | ||||||
|  | if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then | ||||||
|  |   cd "$(dirname "$0")" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | exec "$JAVACMD" "$@" | ||||||
							
								
								
									
										84
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,84 @@ | |||||||
|  | @if "%DEBUG%" == "" @echo off | ||||||
|  | @rem ########################################################################## | ||||||
|  | @rem | ||||||
|  | @rem  Gradle startup script for Windows | ||||||
|  | @rem | ||||||
|  | @rem ########################################################################## | ||||||
|  | 
 | ||||||
|  | @rem Set local scope for the variables with windows NT shell | ||||||
|  | if "%OS%"=="Windows_NT" setlocal | ||||||
|  | 
 | ||||||
|  | set DIRNAME=%~dp0 | ||||||
|  | if "%DIRNAME%" == "" set DIRNAME=. | ||||||
|  | set APP_BASE_NAME=%~n0 | ||||||
|  | set APP_HOME=%DIRNAME% | ||||||
|  | 
 | ||||||
|  | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | set DEFAULT_JVM_OPTS= | ||||||
|  | 
 | ||||||
|  | @rem Find java.exe | ||||||
|  | if defined JAVA_HOME goto findJavaFromJavaHome | ||||||
|  | 
 | ||||||
|  | set JAVA_EXE=java.exe | ||||||
|  | %JAVA_EXE% -version >NUL 2>&1 | ||||||
|  | if "%ERRORLEVEL%" == "0" goto init | ||||||
|  | 
 | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  | 
 | ||||||
|  | goto fail | ||||||
|  | 
 | ||||||
|  | :findJavaFromJavaHome | ||||||
|  | set JAVA_HOME=%JAVA_HOME:"=% | ||||||
|  | set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||||||
|  | 
 | ||||||
|  | if exist "%JAVA_EXE%" goto init | ||||||
|  | 
 | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  | 
 | ||||||
|  | goto fail | ||||||
|  | 
 | ||||||
|  | :init | ||||||
|  | @rem Get command-line arguments, handling Windows variants | ||||||
|  | 
 | ||||||
|  | if not "%OS%" == "Windows_NT" goto win9xME_args | ||||||
|  | 
 | ||||||
|  | :win9xME_args | ||||||
|  | @rem Slurp the command line arguments. | ||||||
|  | set CMD_LINE_ARGS= | ||||||
|  | set _SKIP=2 | ||||||
|  | 
 | ||||||
|  | :win9xME_args_slurp | ||||||
|  | if "x%~1" == "x" goto execute | ||||||
|  | 
 | ||||||
|  | set CMD_LINE_ARGS=%* | ||||||
|  | 
 | ||||||
|  | :execute | ||||||
|  | @rem Setup the command line | ||||||
|  | 
 | ||||||
|  | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||||||
|  | 
 | ||||||
|  | @rem Execute Gradle | ||||||
|  | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | ||||||
|  | 
 | ||||||
|  | :end | ||||||
|  | @rem End local scope for the variables with windows NT shell | ||||||
|  | if "%ERRORLEVEL%"=="0" goto mainEnd | ||||||
|  | 
 | ||||||
|  | :fail | ||||||
|  | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||||||
|  | rem the _cmd.exe /c_ return code! | ||||||
|  | if  not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | ||||||
|  | exit /b 1 | ||||||
|  | 
 | ||||||
|  | :mainEnd | ||||||
|  | if "%OS%"=="Windows_NT" endlocal | ||||||
|  | 
 | ||||||
|  | :omega | ||||||
							
								
								
									
										2
									
								
								settings.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,2 @@ | |||||||
|  | include ':app' | ||||||
|  | rootProject.name = "Schockwelle" | ||||||