Projektteil 2
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

EarthquakeLocation.java 10KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. package de.edotzlaff.detection;
  2. import android.hardware.Sensor;
  3. import android.hardware.SensorEvent;
  4. import android.hardware.SensorEventListener;
  5. import android.hardware.SensorManager;
  6. import android.os.Build;
  7. import android.os.CountDownTimer;
  8. import android.provider.ContactsContract;
  9. import android.util.Log;
  10. import androidx.annotation.NonNull;
  11. import androidx.annotation.RequiresApi;
  12. import androidx.fragment.app.FragmentActivity;
  13. import android.os.Bundle;
  14. import android.widget.Toast;
  15. import com.google.android.gms.maps.CameraUpdateFactory;
  16. import com.google.android.gms.maps.GoogleMap;
  17. import com.google.android.gms.maps.OnMapReadyCallback;
  18. import com.google.android.gms.maps.SupportMapFragment;
  19. import com.google.android.gms.maps.model.BitmapDescriptorFactory;
  20. import com.google.android.gms.maps.model.LatLng;
  21. import com.google.android.gms.maps.model.MarkerOptions;
  22. import com.google.android.gms.tasks.OnCompleteListener;
  23. import com.google.android.gms.tasks.Task;
  24. import com.google.firebase.database.DataSnapshot;
  25. import com.google.firebase.database.DatabaseReference;
  26. import com.google.firebase.database.FirebaseDatabase;
  27. import de.edotzlaff.detection.detektion.Detektionssignal;
  28. import de.edotzlaff.detection.detektion.Epizentrum;
  29. import de.edotzlaff.detection.detektion.Erdbeben;
  30. import de.edotzlaff.detection.detektion.berechnung.mathObjekte.Koordinaten;
  31. import java.time.LocalDateTime;
  32. import java.time.format.DateTimeFormatter;
  33. import java.util.ArrayList;
  34. import java.util.Objects;
  35. public class EarthquakeLocation extends FragmentActivity implements OnMapReadyCallback {
  36. private GoogleMap mMap;
  37. private static final String TAGEPIZENTRUM = "Epizentrum";
  38. private DatabaseReference mDatenbank;
  39. private double latitudeD1, latitudeD2, latitudeD3, latitudeD4;
  40. private double longitudeD1, longitudeD2, longitudeD3, longitudeD4;
  41. private String dev1, dev2, dev3, dev4;
  42. @Override
  43. protected void onCreate(Bundle savedInstanceState) {
  44. super.onCreate(savedInstanceState);
  45. setContentView(R.layout.activity_earthquake_location);
  46. getLocationInfo();
  47. // Obtain the SupportMapFragment and get notified when the map is ready to be used.
  48. SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map);
  49. mapFragment.getMapAsync(this);
  50. }
  51. //##########################################################################################################################################################################
  52. //################################################################## vvv DB Code vvv #####################################################################################
  53. public void getLocationInfo()
  54. {
  55. mDatenbank = FirebaseDatabase.getInstance().getReference().child("overviewdetection");
  56. mDatenbank.get().addOnCompleteListener(new OnCompleteListener<DataSnapshot>() {
  57. @RequiresApi(api = Build.VERSION_CODES.O)
  58. @Override
  59. public void onComplete(@NonNull Task<DataSnapshot> task) {
  60. if (!task.isSuccessful()) {
  61. System.out.println("Datenbank Fehler in getDataBaseValuesNoListener");
  62. }
  63. else{
  64. defineGPSforMapping(task.getResult());
  65. //ermittleEpizentrum(task.getResult());
  66. //mapToDetektionssignale(task.getResult());
  67. }
  68. }
  69. });
  70. }
  71. public void defineGPSforMapping(DataSnapshot data)
  72. {
  73. String breitengradString;
  74. String laengengradString;
  75. String androidID;
  76. for(int i =1; i<=3; i++)
  77. {
  78. breitengradString = data.child("IDG" + i).child("d_breitengrad").getValue().toString();
  79. laengengradString = data.child("IDG" + i).child("e_laengengrad").getValue().toString();
  80. androidID = data.child("IDG" + i).child("a_androidid").getValue().toString();
  81. double breitengrad = Double.parseDouble(breitengradString);
  82. double laengengrad = Double.parseDouble(laengengradString);
  83. switch (i){
  84. case 1:
  85. latitudeD1 = breitengrad;
  86. longitudeD1 = laengengrad;
  87. dev1 = androidID;
  88. break;
  89. case 2:
  90. latitudeD2 = breitengrad;
  91. longitudeD2 = laengengrad;
  92. dev2 = androidID;
  93. break;
  94. case 3:
  95. latitudeD3 = breitengrad;
  96. longitudeD3 = laengengrad;
  97. dev3 = androidID;
  98. break;
  99. default:
  100. break;
  101. }
  102. }
  103. }
  104. //################################################################## ^^^^ DB Code ^^^^ ###################################################################################
  105. //##########################################################################################################################################################################
  106. //##########################################################################################################################################################################
  107. //################################################################## vvv Calculate Epicenter vvv #########################################################################
  108. @RequiresApi(api = Build.VERSION_CODES.O)
  109. public Epizentrum ermittleEpizentrum(DataSnapshot data)
  110. {
  111. System.out.println("############## EPIZENTRUM ###############");
  112. Erdbeben erdbeben = new Erdbeben();
  113. erdbeben.addDetektionssignalList(mapToDetektionssignale(data));
  114. Epizentrum epizentrum = new Epizentrum();
  115. epizentrum = erdbeben.ermittleEpizentrum();
  116. if(Objects.isNull(epizentrum))
  117. {
  118. Log.i(TAGEPIZENTRUM, "Kein Epizentrum vorhanden");
  119. }
  120. else
  121. {
  122. Log.i(TAGEPIZENTRUM, "Epizentrum konnte ermittelt werden, Koordinaten: " + epizentrum.getKoordinaten().getX() + " " + epizentrum.getKoordinaten().getY());
  123. }
  124. return epizentrum;
  125. }
  126. @RequiresApi(api = Build.VERSION_CODES.O)
  127. public ArrayList<Detektionssignal> mapToDetektionssignale(DataSnapshot data)
  128. {
  129. System.out.println("################# ARRAYLIST ####################");
  130. ArrayList<Detektionssignal> detektionssignale = new ArrayList<>();
  131. for(int i=1; i<=3; i++)
  132. {
  133. Detektionssignal detektionssignal = new Detektionssignal();
  134. //LocalDateTime als LocalDateTime
  135. String localdatetimeString = data.child("IDG" + i).child("b_localdatetime").getValue().toString();
  136. DateTimeFormatter formatter = DateTimeFormatter.ISO_DATE_TIME;
  137. LocalDateTime localdatetime = LocalDateTime.parse(localdatetimeString, formatter);
  138. detektionssignal.setAnkunftsZeit(localdatetime);
  139. //ID als String
  140. detektionssignal.setDeviceId(data.child("IDG" + i).child("a_androidid").getValue().toString());
  141. //Koordinaten
  142. String breitengradString = data.child("IDG" + i).child("d_breitengrad").getValue().toString();
  143. String laengengradString = data.child("IDG" + i).child("e_laengengrad").getValue().toString();
  144. double breitengrad = Double.parseDouble(breitengradString);
  145. double laengengrad = Double.parseDouble(laengengradString);
  146. Koordinaten koordinaten = new Koordinaten(breitengrad, laengengrad);
  147. detektionssignal.setKoordinaten(koordinaten);
  148. //Welle in m/s
  149. String welle = data.child("IDG" + i).child("w_wellengeschwindigkeit").getValue().toString();
  150. int wellengeschwindigkeit = Integer.parseInt(welle);
  151. detektionssignal.setGeschwErdbeben(wellengeschwindigkeit);
  152. detektionssignale.add(detektionssignal);
  153. }
  154. return detektionssignale;
  155. }
  156. //################################################################## ^^^^ Calculate Epicenter ^^^^ #######################################################################
  157. //##########################################################################################################################################################################
  158. //##########################################################################################################################################################################
  159. //################################################################## vvv Maps Code vvv ###################################################################################
  160. @Override
  161. public void onMapReady(GoogleMap googleMap) {
  162. mMap = googleMap;
  163. //TODO Aron: Daten aus DB in die jeweiligen Devices einsetzten
  164. //aus DB für Device 1 long lat
  165. LatLng device1 = new LatLng(latitudeD1, longitudeD1);
  166. mMap.addMarker(new MarkerOptions().position(device1).title("Device 1").icon(BitmapDescriptorFactory
  167. .defaultMarker(BitmapDescriptorFactory.HUE_GREEN)));
  168. //aus DB für Device 2 long lat
  169. LatLng device2 = new LatLng(latitudeD2, longitudeD2);
  170. mMap.addMarker(new MarkerOptions().position(device2).title("Device 2").icon(BitmapDescriptorFactory
  171. .defaultMarker(BitmapDescriptorFactory.HUE_GREEN)));
  172. //aus DB für Device 3 long lat
  173. LatLng device3 = new LatLng(latitudeD3, longitudeD3);
  174. mMap.addMarker(new MarkerOptions().position(device3).title("Device 3").icon(BitmapDescriptorFactory
  175. .defaultMarker(BitmapDescriptorFactory.HUE_GREEN)));
  176. //man könnten noch eine IF Abfrage einbauen falls es 4 Devices gibt
  177. // Add a marker in Epicenter
  178. LatLng epicenter = new LatLng(-34, 151);
  179. mMap.addMarker(new MarkerOptions().position(epicenter).title("Epicenter"));
  180. mMap.moveCamera(CameraUpdateFactory.newLatLng(epicenter));
  181. }
  182. //################################################################## ^^^^ Maps Code ^^^^ #################################################################################
  183. //##########################################################################################################################################################################
  184. }