Projektarbeit
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.

MainActivity.java 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. package de.edotzlaff.schockwelle;
  2. import androidx.annotation.NonNull;
  3. import androidx.annotation.RequiresApi;
  4. import androidx.appcompat.app.AppCompatActivity;
  5. import androidx.fragment.app.FragmentActivity;
  6. import android.app.ActionBar;
  7. import android.app.Dialog;
  8. import android.content.Intent;
  9. import android.hardware.Sensor;
  10. import android.os.Build;
  11. import android.os.Bundle;
  12. import android.provider.Settings;
  13. import android.util.Log;
  14. import android.view.View;
  15. import android.widget.Button;
  16. import android.widget.Toast;
  17. import com.google.android.gms.common.ConnectionResult;
  18. import com.google.android.gms.common.GoogleApiAvailability;
  19. import com.google.android.gms.tasks.OnCompleteListener;
  20. import com.google.android.gms.tasks.Task;
  21. import com.google.firebase.database.DataSnapshot;
  22. import com.google.firebase.database.DatabaseError;
  23. import com.google.firebase.database.DatabaseReference;
  24. import com.google.firebase.database.FirebaseDatabase;
  25. import com.google.firebase.database.ValueEventListener;
  26. import java.time.LocalDateTime;
  27. import java.time.format.DateTimeFormatter;
  28. import java.util.Calendar;
  29. public class MainActivity extends FragmentActivity {
  30. private static final String TAG = "MainActivity";
  31. private static final int ERROR_DIALOG_REQUEST = 9001;
  32. private DatabaseReference mDatenbank;
  33. String android_id;
  34. @Override
  35. protected void onCreate(Bundle savedInstanceState) {
  36. super.onCreate(savedInstanceState);
  37. setContentView(R.layout.activity_main);
  38. if (isServiceOK()){
  39. init();
  40. }
  41. }
  42. private void init(){
  43. Button btnEarthquake = (Button) findViewById(R.id.btnEarthquake);
  44. Button btnSensor = (Button) findViewById(R.id.btnSensor);
  45. Button btnMuster = (Button) findViewById(R.id.buttonDatenBankMuster);
  46. Button btnLeer = (Button) findViewById(R.id.buttonDatenBankLeeren);
  47. Button btnReset = (Button) findViewById(R.id.buttonReset);
  48. btnEarthquake.setEnabled(false);
  49. btnEarthquake.setOnClickListener(new View.OnClickListener() {
  50. @Override
  51. public void onClick(View v) {
  52. Intent intent = new Intent(MainActivity.this, EarthquakeMapsActivity.class);
  53. btnEarthquake.setEnabled(false);
  54. btnSensor.setEnabled(false);
  55. startActivity(intent);
  56. }
  57. });
  58. btnSensor.setEnabled(false);
  59. btnSensor.setOnClickListener(new View.OnClickListener() {
  60. @Override
  61. public void onClick(View v) {
  62. Intent intent = new Intent(MainActivity.this, SensorMapsActivity.class);
  63. btnSensor.setEnabled(false);
  64. btnEarthquake.setEnabled(false);
  65. startActivity(intent);
  66. }
  67. });
  68. btnMuster.setOnClickListener(new View.OnClickListener() {
  69. @Override
  70. public void onClick(View v) {
  71. btnEarthquake.setEnabled(true);
  72. btnSensor.setEnabled(true);
  73. btnLeer.setEnabled(false);
  74. btnMuster.setEnabled(false);
  75. btnReset.setEnabled(true);
  76. deviceInitDataBase();
  77. }
  78. });
  79. btnLeer.setOnClickListener(new View.OnClickListener() {
  80. @Override
  81. public void onClick(View v) {
  82. btnEarthquake.setEnabled(true);
  83. btnSensor.setEnabled(true);
  84. btnMuster.setEnabled(false);
  85. btnReset.setEnabled(true);
  86. btnLeer.setEnabled(false);
  87. datenBankLeeren();
  88. }
  89. });
  90. btnReset.setEnabled(false);
  91. btnReset.setOnClickListener(new View.OnClickListener() {
  92. @Override
  93. public void onClick(View v) {
  94. getDataBaseValuesNoListener();
  95. btnEarthquake.setEnabled(true);
  96. btnSensor.setEnabled(true);
  97. btnMuster.setEnabled(true);
  98. btnLeer.setEnabled(true);
  99. }
  100. });
  101. }
  102. public boolean isServiceOK(){
  103. Log.d(TAG, "isServicesOK(): checking google services version");
  104. int available = GoogleApiAvailability.getInstance().isGooglePlayServicesAvailable(MainActivity.this);
  105. if (available== ConnectionResult.SUCCESS){
  106. Log.d(TAG,"isServicesOK: Google Play Services is working");
  107. return true;
  108. }
  109. else if (GoogleApiAvailability.getInstance().isUserResolvableError(available)){
  110. Log.d(TAG, "isServicesOK(): an error occured but we can fix it");
  111. Dialog dialog = GoogleApiAvailability.getInstance().getErrorDialog(MainActivity.this, available, ERROR_DIALOG_REQUEST);
  112. dialog.show();
  113. }
  114. else {
  115. Toast.makeText(this, "You can`t make map request", Toast.LENGTH_SHORT).show();
  116. }
  117. return false;
  118. }
  119. public void deviceInitDataBase()
  120. {
  121. mDatenbank = FirebaseDatabase.getInstance().getReference();
  122. 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
  123. 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
  124. 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
  125. 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
  126. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG1").setValue(d1);
  127. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG2").setValue(d2);
  128. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG3").setValue(d3);
  129. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG4").setValue(d4);
  130. //Nürnberg HBF: 49.4474136331757, 11.082661293035727
  131. }
  132. //Datenbank auslesen OHNE Listener. D.h. es werden Daten (snapshot) ausgelesen und kein Listener hinterlegt.
  133. //Sollten sich danach Daten zu einem beliebigen Zeitpunkt in der DB ändern, wird die Funktion "onDataChange" NICHT erneut ausgelöst.
  134. public void getDataBaseValuesNoListener()
  135. {
  136. mDatenbank = FirebaseDatabase.getInstance().getReference();
  137. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").get().addOnCompleteListener(new OnCompleteListener<DataSnapshot>() {
  138. @Override
  139. public void onComplete(@NonNull Task<DataSnapshot> task) {
  140. if (!task.isSuccessful()) {
  141. System.out.println("Error getting data: " + task.getException());
  142. }
  143. else {
  144. testProcess(task.getResult());
  145. }
  146. }
  147. });
  148. }
  149. public void datenBankLeeren()
  150. {
  151. mDatenbank = FirebaseDatabase.getInstance().getReference();
  152. for (int i = 1; i<=4; i++)
  153. {
  154. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("ip").setValue("");
  155. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("vibration").setValue(false);
  156. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("timestamp").setValue("");
  157. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("breitengrad").setValue("");
  158. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("laengengrad").setValue("");
  159. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("amplitude").setValue("");
  160. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("localdatetime").setValue("");
  161. mDatenbank.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("androidid").setValue("");
  162. }
  163. }
  164. public void testProcess(DataSnapshot data)
  165. {
  166. mDatenbank = FirebaseDatabase.getInstance().getReference().child("overviewAronTestetInDiesemAbschnitt");
  167. }
  168. }
  169. /*
  170. //Datenbank auslesen MIT Listener. D.h. es werden Daten (snapshot) ausgelesen und gleichzeitig ein Listener hinterlegt.
  171. //Sollten sich danach Daten zu einem beliebigen Zeitpunkt in der DB ändern, wird die Funktion "onDataChange" erneut ausgelöst und wieder Daten (snapshot) ausgelesen.
  172. public void getDataBaseValuesListener()
  173. {
  174. mDatenbank = FirebaseDatabase.getInstance().getReference();
  175. mDatenbank.addValueEventListener(new ValueEventListener() {
  176. @Override
  177. public void onDataChange(@NonNull DataSnapshot snapshot) {
  178. //testProcess(snapshot); //Daten - Snapshot, Übergabe an Methode processDataBaseValues
  179. }
  180. @Override
  181. public void onCancelled(@NonNull DatabaseError error) {
  182. getDataBaseFailure(error);
  183. }
  184. });
  185. }
  186. */
  187. /*
  188. public void getDataBaseFailure (DatabaseError error)
  189. {
  190. System.out.println("Fehler");
  191. Log.w("Datenbankfehler", error.toException());
  192. }
  193. */
  194. /*
  195. @RequiresApi(api = Build.VERSION_CODES.O)
  196. public void processDataBaseValues (DataSnapshot data)
  197. {
  198. for (int i = 1; i<=4; i++) //Für alle IDG 1-4 werden Werte ausgegeben
  199. {
  200. //####### Auslesen für String-Werte #######:
  201. String ipAdresse = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("ip").getValue().toString();
  202. //####### Auslesen für boolean-Werte #######:
  203. String vibrationString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("vibration").getValue().toString();
  204. boolean vibration;
  205. if(vibrationString == "true"){
  206. vibration = true;
  207. }else{
  208. vibration = false;
  209. }
  210. //####### Auslesen für double-Werte #######:
  211. String breitengradString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("breitengrad").getValue().toString();
  212. String laengengradString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("laengengrad").getValue().toString();
  213. double breitengrad = Double.parseDouble(breitengradString);
  214. double laengengrad = Double.parseDouble(laengengradString);
  215. //####### Auslesen für long-Werte #######:
  216. String timestampString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("timestamp").getValue().toString();
  217. long timestamp = Long.parseLong(timestampString);
  218. //####### Auslesen für ing-Werte #######:
  219. String amplitudeString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("amplitude").getValue().toString();
  220. int amplitude = Integer.parseInt(amplitudeString);
  221. //####### Auslesen für LocalDateTime#######:
  222. String localdatetimeString = data.child("overviewAronTestetInDiesemAbschnitt").child("IDG" + i).child("localdatetime").getValue().toString();
  223. DateTimeFormatter formatter = DateTimeFormatter.ISO_DATE_TIME;
  224. LocalDateTime localdatetime = LocalDateTime.parse(localdatetimeString, formatter);
  225. }
  226. }
  227. */