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 11KB

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