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. Log.i(TAGEPIZENTRUM, "Start Ermittle Epizentrum");
  112. Erdbeben erdbeben = new Erdbeben();
  113. erdbeben.addDetektionssignalList(mapToDetektionssignale(data));
  114. Epizentrum epizentrum = erdbeben.ermittleEpizentrum();
  115. if(Objects.isNull(epizentrum))
  116. {
  117. System.out.println("!!!!!!!!!!!!!!!!!!!!!!!!!Kein Epizentrum vorhanden!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
  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. ArrayList<Detektionssignal> detektionssignale = new ArrayList<>();
  130. for(int i=1; i<=3; i++)
  131. {
  132. Detektionssignal detektionssignal = new Detektionssignal();
  133. //LocalDateTime als LocalDateTime
  134. String localdatetimeString = data.child("IDG" + i).child("b_localdatetime").getValue().toString();
  135. DateTimeFormatter formatter = DateTimeFormatter.ISO_DATE_TIME;
  136. LocalDateTime localdatetime = LocalDateTime.parse(localdatetimeString, formatter);
  137. detektionssignal.setAnkunftsZeit(localdatetime);
  138. //ID als String
  139. detektionssignal.setDeviceId(data.child("IDG" + i).child("a_androidid").getValue().toString());
  140. //Koordinaten
  141. String breitengradString = data.child("IDG" + i).child("d_breitengrad").getValue().toString();
  142. String laengengradString = data.child("IDG" + i).child("e_laengengrad").getValue().toString();
  143. double breitengrad = Double.parseDouble(breitengradString);
  144. double laengengrad = Double.parseDouble(laengengradString);
  145. Koordinaten koordinaten = new Koordinaten(breitengrad, laengengrad);
  146. detektionssignal.setKoordinaten(koordinaten);
  147. //Welle in m/s
  148. String welle = data.child("IDG" + i).child("w_wellengeschwindigkeit").getValue().toString();
  149. int wellengeschwindigkeit = Integer.parseInt(welle);
  150. detektionssignal.setGeschwErdbeben(wellengeschwindigkeit);
  151. detektionssignale.add(detektionssignal);
  152. }
  153. return detektionssignale;
  154. }
  155. //################################################################## ^^^^ Calculate Epicenter ^^^^ #######################################################################
  156. //##########################################################################################################################################################################
  157. //##########################################################################################################################################################################
  158. //################################################################## vvv Maps Code vvv ###################################################################################
  159. @Override
  160. public void onMapReady(GoogleMap googleMap) {
  161. mMap = googleMap;
  162. //TODO Aron: Daten aus DB in die jeweiligen Devices einsetzten
  163. //aus DB für Device 1 long lat
  164. LatLng device1 = new LatLng(latitudeD1, longitudeD1);
  165. mMap.addMarker(new MarkerOptions().position(device1).title("Device 1").icon(BitmapDescriptorFactory
  166. .defaultMarker(BitmapDescriptorFactory.HUE_GREEN)));
  167. //aus DB für Device 2 long lat
  168. LatLng device2 = new LatLng(latitudeD2, longitudeD2);
  169. mMap.addMarker(new MarkerOptions().position(device2).title("Device 2").icon(BitmapDescriptorFactory
  170. .defaultMarker(BitmapDescriptorFactory.HUE_GREEN)));
  171. //aus DB für Device 3 long lat
  172. LatLng device3 = new LatLng(latitudeD3, longitudeD3);
  173. mMap.addMarker(new MarkerOptions().position(device3).title("Device 3").icon(BitmapDescriptorFactory
  174. .defaultMarker(BitmapDescriptorFactory.HUE_GREEN)));
  175. //man könnten noch eine IF Abfrage einbauen falls es 4 Devices gibt
  176. // Add a marker in Epicenter
  177. LatLng epicenter = new LatLng(-34, 151);
  178. mMap.addMarker(new MarkerOptions().position(epicenter).title("Epicenter"));
  179. mMap.moveCamera(CameraUpdateFactory.newLatLng(epicenter));
  180. }
  181. //################################################################## ^^^^ Maps Code ^^^^ #################################################################################
  182. //##########################################################################################################################################################################
  183. }