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.

SensorMapsActivity.java 26KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604
  1. package de.edotzlaff.schockwelle;
  2. import android.Manifest;
  3. import android.content.Context;
  4. import android.content.Intent;
  5. import android.content.pm.PackageManager;
  6. import android.location.Location;
  7. import android.net.wifi.WifiManager;
  8. import android.os.Build;
  9. import android.os.Bundle;
  10. import android.os.CountDownTimer;
  11. import android.os.VibrationEffect;
  12. import android.os.Vibrator;
  13. import android.provider.Settings;
  14. import android.util.Log;
  15. import android.widget.TextView;
  16. import android.widget.Toast;
  17. import androidx.annotation.NonNull;
  18. import androidx.core.app.ActivityCompat;
  19. import androidx.core.content.ContextCompat;
  20. import androidx.fragment.app.FragmentActivity;
  21. import com.google.android.gms.location.FusedLocationProviderClient;
  22. import com.google.android.gms.location.LocationServices;
  23. import com.google.android.gms.maps.CameraUpdateFactory;
  24. import com.google.android.gms.maps.GoogleMap;
  25. import com.google.android.gms.maps.OnMapReadyCallback;
  26. import com.google.android.gms.maps.SupportMapFragment;
  27. import com.google.android.gms.maps.model.LatLng;
  28. import com.google.android.gms.maps.model.MarkerOptions;
  29. import com.google.android.gms.tasks.OnCompleteListener;
  30. import com.google.android.gms.tasks.Task;
  31. import com.google.firebase.database.DataSnapshot;
  32. import com.google.firebase.database.DatabaseError;
  33. import com.google.firebase.database.DatabaseReference;
  34. import com.google.firebase.database.FirebaseDatabase;
  35. import com.google.firebase.database.ValueEventListener;
  36. import java.time.LocalDateTime;
  37. import java.util.Calendar;
  38. import java.util.Date;
  39. public class SensorMapsActivity extends FragmentActivity implements OnMapReadyCallback {
  40. private static final String TAG = "MainActivity";
  41. private static final String FINE_LOCATION = Manifest.permission.ACCESS_FINE_LOCATION;
  42. private static final int LOCATION_PERMISSION_REQUEST_CODE = 1234;
  43. private static final double EARTHQUAKE_VELOCITY = 1; // 1 Meter pro Sekunde Erdbebengeschwindigkeit
  44. //vars
  45. private Boolean mLocationPermissionsGranted = false;
  46. private GoogleMap mMap;
  47. private FusedLocationProviderClient mFusedLocationProviderClient;
  48. //Date currentTime;
  49. Location currentLocation;
  50. Long currentTime;
  51. private double breitengrad;
  52. private double laengengrad;
  53. private double sensorGPSbreitengrad;
  54. private double sensorGPSlaengengrad;
  55. private boolean useOwnGPS;
  56. private boolean takeGPSfromDB = true;
  57. private boolean tookOwnGPS = false;
  58. private boolean globalShit = true;
  59. private boolean permissionToWriteToDataBase = true;
  60. boolean vibrationTrigger = true;
  61. boolean grabGPSandID = true;
  62. private DatabaseReference mDatenbank;
  63. private String breitengradQuellVibration;
  64. private String laengengradQuellVibration;
  65. private Boolean mDeviceCanVibrate = false;
  66. @Override
  67. protected void onCreate(Bundle savedInstanceState) {
  68. super.onCreate(savedInstanceState);
  69. setContentView(R.layout.activity_sensor_maps);
  70. getDataBaseValuesWithListener();
  71. TextView tv= (TextView) findViewById(R.id.txtSensor);
  72. getLocationPermission(); //Zuerst werden die aktuellen Standortdaten ermittelt
  73. getVibrationAbility();
  74. System.out.println("Global Shit: " + globalShit);
  75. }
  76. @Override
  77. protected void onPause()
  78. {
  79. super.onPause();
  80. }
  81. @Override
  82. protected void onResume()
  83. {
  84. super.onResume();
  85. }
  86. //#####################################################################################################################################################################
  87. //################################################################## vvv ShakeCode vvv ##############################################################################
  88. private void getVibrationAbility()
  89. {
  90. // Get instance of Vibrator from current Context
  91. Vibrator v = (Vibrator) getSystemService(Context.VIBRATOR_SERVICE);
  92. // Output yes if can vibrate, no otherwise
  93. if (v.hasVibrator()) {
  94. Log.v("Can Vibrate", "YES");
  95. // Log.v("Can Control Amplitude", v.hasAmplitudeControl() ? "YES" : "NO");
  96. mDeviceCanVibrate = true;
  97. }
  98. else
  99. {
  100. Log.v("Can Vibrate", "NO");
  101. mDeviceCanVibrate = false;
  102. }
  103. }
  104. private void setVibrationTimer(long msDelay, int duration, int amplitude, int index)
  105. {
  106. System.out.println("!!!!!!!!!!!!!!!!!!!!!!!!!!!!setVibrationTimer wurde getriggert mit Index " + index);
  107. new CountDownTimer(msDelay, 1000) {
  108. public void onTick(long millisUntilFinished) {
  109. ((TextView) findViewById(R.id.txtSensor)).setText("Earthquake hits in " + millisUntilFinished / 1000 + " s");
  110. }
  111. public void onFinish() {
  112. Toast.makeText(getApplicationContext(), "The Ground is shaking!", Toast.LENGTH_SHORT).show();
  113. performVibration(duration, amplitude);
  114. ( (TextView) findViewById(R.id.txtSensor)).setText("No Earthquake upcoming");
  115. //Hier wird tatsächlich die DB beschrieben sobald der Timer abgelaufen ist
  116. setVibrationInDataBase(index);
  117. }
  118. }.start();
  119. }
  120. public void performVibration(int duration, int amplitude) {
  121. if(!mDeviceCanVibrate)
  122. return;
  123. Vibrator v = (Vibrator) getSystemService(Context.VIBRATOR_SERVICE);
  124. if(amplitude > 255 || amplitude < 1)
  125. amplitude = VibrationEffect.DEFAULT_AMPLITUDE;
  126. if (Build.VERSION.SDK_INT >= 26) {
  127. if(duration == 0)
  128. {
  129. v.cancel(); //stop vibration if still running
  130. Toast.makeText(this, "Vibration has been stopped", Toast.LENGTH_SHORT).show();
  131. return;
  132. }
  133. Toast.makeText(this, "Ampl: " + amplitude + ", Dur: " + duration, Toast.LENGTH_SHORT).show();
  134. v.vibrate(VibrationEffect.createOneShot(duration,amplitude));
  135. } else {
  136. if(duration == 0)
  137. {
  138. v.cancel(); //stop vibration if still running
  139. return;
  140. }
  141. v.vibrate(duration);
  142. }
  143. }
  144. //################################################################## ^^^^ ShakeCode ^^^^ ############################################################################
  145. //#####################################################################################################################################################################
  146. //#####################################################################################################################################################################
  147. //################################################################## vvv GPS Code vvv ###############################################################################
  148. private void getLocationPermission() {
  149. String[] permissions = {Manifest.permission.ACCESS_FINE_LOCATION};
  150. if (ContextCompat.checkSelfPermission(this.getApplicationContext(), FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) {
  151. mLocationPermissionsGranted = true;
  152. initMap();
  153. } else {
  154. ActivityCompat.requestPermissions(this, permissions, LOCATION_PERMISSION_REQUEST_CODE);
  155. }
  156. }
  157. @Override
  158. public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
  159. super.onRequestPermissionsResult(requestCode, permissions, grantResults);
  160. mLocationPermissionsGranted = false;
  161. switch (requestCode) {
  162. case LOCATION_PERMISSION_REQUEST_CODE: {
  163. if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
  164. mLocationPermissionsGranted = true;
  165. //initalize or map
  166. initMap();
  167. }
  168. }
  169. }
  170. }
  171. void initMap(){
  172. // Obtain the SupportMapFragment and get notified when the map is ready to be used.
  173. SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
  174. .findFragmentById(R.id.map);
  175. mapFragment.getMapAsync(this);
  176. }
  177. @Override
  178. public void onMapReady(GoogleMap googleMap) {
  179. Toast.makeText(this, "Map is ready", Toast.LENGTH_SHORT).show();
  180. mMap = googleMap;
  181. if (mLocationPermissionsGranted) {
  182. getDeviceLocation();
  183. if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION)
  184. != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this,
  185. Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
  186. return;
  187. }
  188. mMap.setMyLocationEnabled(true);
  189. }
  190. //TODO @ Eddy: Ich denke diesen Code brauchst du noch, oder? :D
  191. //Add a marker in Sydney and move the camera
  192. //LatLng sydney = new LatLng(-34, 151);
  193. //mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
  194. //mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
  195. }
  196. private void getDeviceLocation(){
  197. mFusedLocationProviderClient = LocationServices.getFusedLocationProviderClient(this);
  198. try {
  199. if (mLocationPermissionsGranted){
  200. final Task location = mFusedLocationProviderClient.getLastLocation();
  201. location.addOnCompleteListener(new OnCompleteListener() {
  202. @Override
  203. public void onComplete(@NonNull Task task) {
  204. if (task.isSuccessful()){
  205. currentLocation = (Location) task.getResult();
  206. currentTime = Calendar.getInstance().getTimeInMillis();
  207. if (!useOwnGPS)
  208. {
  209. currentLocation.setLatitude(breitengrad);
  210. currentLocation.setLongitude(laengengrad);
  211. }
  212. Toast.makeText(SensorMapsActivity.this, currentTime.toString(), Toast.LENGTH_SHORT).show();
  213. moveCamera(new LatLng(currentLocation.getLatitude(), currentLocation.getLongitude()),15f);
  214. }
  215. else{
  216. Toast.makeText(SensorMapsActivity.this, "Current Location unavailable", Toast.LENGTH_SHORT).show();
  217. }
  218. }
  219. });
  220. }
  221. }catch (SecurityException e){
  222. Log.e(TAG,"Device Location not found" + e.getMessage());
  223. }
  224. }
  225. private void moveCamera(LatLng latlng, float zoom){
  226. Log.d(TAG,"Latitude: "+latlng.latitude+"Longitude: "+latlng.longitude);
  227. mMap.moveCamera(CameraUpdateFactory.newLatLngZoom(latlng, zoom));
  228. }
  229. //################################################################## ^^^^ GPS Code ^^^^ #############################################################################
  230. //#####################################################################################################################################################################
  231. //#####################################################################################################################################################################
  232. //################################################################## vvv DB Code vvv ###############################################################################
  233. //Datenbank auslesen mit Listener. D.h. es werden Daten (snapshot) ausgelesen und gleichzeitig ein Listener hinterlegt.
  234. //Sollten sich danach Daten zu einem beliebigen Zeitpunkt in der DB ändern, wird die Funktion "onDataChange" erneut ausgelöst und wieder Daten (snapshot) ausgelesen.
  235. public void getDataBaseValuesWithListener()
  236. {
  237. mDatenbank = FirebaseDatabase.getInstance().getReference();
  238. mDatenbank.addValueEventListener(new ValueEventListener() {
  239. @Override
  240. public void onDataChange(@NonNull DataSnapshot snapshot) {
  241. processDataBaseUpdate(snapshot);
  242. }
  243. @Override
  244. public void onCancelled(@NonNull DatabaseError error) {
  245. getDataBaseFailure(error);
  246. }
  247. });
  248. }
  249. public boolean analyzeForUseOfOwnGPS(DataSnapshot data)
  250. {
  251. String nativeGPSString;
  252. boolean nativeGPS;
  253. int amountNativeGPSisTrue = 0;
  254. int indexMax = (int) data.child("overviewnodes").getChildrenCount();
  255. for (int i = 1; i <= indexMax; i++)
  256. {
  257. nativeGPSString = data.child("overviewnodes").child("IDG" + i).child("f_nativegps").getValue().toString();
  258. if(nativeGPSString.equals("true"))
  259. {
  260. amountNativeGPSisTrue++;
  261. }else
  262. {
  263. amountNativeGPSisTrue--;
  264. }
  265. }
  266. if(amountNativeGPSisTrue == indexMax)
  267. {
  268. nativeGPS = true;
  269. }else{
  270. nativeGPS = false;
  271. }
  272. return nativeGPS;
  273. }
  274. public boolean analyzeIfAnroidIdIsEmpty(DataSnapshot data, int k)
  275. {
  276. String androidid;
  277. int indexMax = (int) data.child("overviewnodes").getChildrenCount();
  278. boolean androididempty = false;
  279. for (int i = k; i <= k; i++)
  280. {
  281. androidid = data.child("overviewnodes").child("IDG" + i).child("a_androidid").getValue().toString();
  282. if(androidid.isEmpty())
  283. {
  284. androididempty = true;
  285. }else
  286. {
  287. androididempty = false;
  288. }
  289. }
  290. return androididempty;
  291. }
  292. public boolean analyzeForOwnAndroidID(DataSnapshot data, int k)
  293. {
  294. String androididString;
  295. boolean ownAndroidID = false;
  296. int indexMax = (int) data.child("overviewnodes").getChildrenCount();
  297. for (int i = k; i <= k; i++)
  298. {
  299. androididString = data.child("overviewnodes").child("IDG" + i).child("a_androidid").getValue().toString();
  300. if(androididString.equals(getandroidid()))
  301. {
  302. ownAndroidID = true;
  303. }else
  304. {
  305. ownAndroidID = false;
  306. }
  307. }
  308. return ownAndroidID;
  309. }
  310. public boolean analyzeForStateOfVibration(DataSnapshot data, int k)
  311. {
  312. String vibrationString;
  313. boolean stateOfVibration = false;
  314. int indexMax = (int) data.child("overviewnodes").getChildrenCount();
  315. for (int i = k; i <= k; i++)
  316. {
  317. vibrationString = data.child("overviewnodes").child("IDG" + i).child("g_vibration").getValue().toString();
  318. if(vibrationString.equals("true"))
  319. {
  320. stateOfVibration = true;
  321. }else
  322. {
  323. stateOfVibration = false;
  324. }
  325. }
  326. return stateOfVibration;
  327. }
  328. public boolean analyzeForExisitingGPSvalues(DataSnapshot data, int k)
  329. {
  330. String breitengradString;
  331. String laengengradString;
  332. boolean bothGPSvaluesExist = false;
  333. int indexMax = (int) data.child("overviewnodes").getChildrenCount();
  334. for (int i = k; i <= k; i++)
  335. {
  336. breitengradString = data.child("overviewnodes").child("IDG" + i).child("d_breitengrad").getValue().toString();
  337. laengengradString = data.child("overviewnodes").child("IDG" + i).child("e_laengengrad").getValue().toString();
  338. if(!breitengradString.isEmpty() && !laengengradString.isEmpty())
  339. {
  340. bothGPSvaluesExist = true;
  341. }else
  342. {
  343. bothGPSvaluesExist = false;
  344. }
  345. }
  346. return bothGPSvaluesExist;
  347. }
  348. public void processDataBaseUpdate (DataSnapshot data)
  349. {
  350. int indexMax = (int) data.child("overviewnodes").getChildrenCount();
  351. //Festellen ob DB oder eigene GPS-Daten verwendet werden sollen
  352. if(analyzeForUseOfOwnGPS(data))
  353. {
  354. useOwnGPS = true;
  355. }
  356. else
  357. {
  358. useOwnGPS = false;
  359. }
  360. //Wichtig zur Verwendung von GPS-Daten explizit aus der Datenbank
  361. if(!useOwnGPS && grabGPSandID)
  362. {
  363. for (int f = 1; f<=indexMax; f++)
  364. {
  365. if(f>=2 && f<=indexMax)
  366. {
  367. if(analyzeIfAnroidIdIsEmpty(data,f))
  368. {
  369. String breitengradString = data.child("overviewnodes").child("IDG" + f).child("d_breitengrad").getValue().toString();
  370. String laengengradString = data.child("overviewnodes").child("IDG" + f).child("e_laengengrad").getValue().toString();
  371. breitengrad = Double.parseDouble(breitengradString);
  372. laengengrad = Double.parseDouble(laengengradString);
  373. allocateIDtoDatabaseSlot(f);
  374. grabGPSandID = false;
  375. break;
  376. }
  377. }
  378. }
  379. }
  380. //Hier sind die Schreibregeln für die DB definiert wenn Sensor aktiviert ist
  381. for (int f = 1; f<=indexMax && permissionToWriteToDataBase; f++)
  382. {
  383. if((!analyzeIfAnroidIdIsEmpty(data,f) && !analyzeForOwnAndroidID(data,f) && analyzeForStateOfVibration(data,f) && analyzeForExisitingGPSvalues(data,f) && permissionToWriteToDataBase))
  384. {
  385. String breitengradString = data.child("overviewnodes").child("IDG" + f).child("d_breitengrad").getValue().toString();
  386. String laengengradString = data.child("overviewnodes").child("IDG" + f).child("e_laengengrad").getValue().toString();
  387. breitengradQuellVibration = breitengradString;
  388. laengengradQuellVibration = laengengradString;
  389. f=1;
  390. if(analyzeForOwnAndroidID(data,f))
  391. {
  392. if (!analyzeForStateOfVibration(data,f))
  393. {
  394. if(analyzeForExisitingGPSvalues(data,f))
  395. {
  396. float distanceToEarthquake;
  397. distanceToEarthquake = distance(currentLocation.getLatitude(), currentLocation.getLongitude(), Double.parseDouble(breitengradQuellVibration), Double.parseDouble(laengengradQuellVibration));
  398. long wellenAusbreitungsGeschwindigkeit = 4500; //Meter die Sekunde
  399. long delayInSeconds = (long) distanceToEarthquake/wellenAusbreitungsGeschwindigkeit; //s
  400. long delayInMilliSeconds = delayInSeconds*1000;
  401. setVibrationTimer(delayInMilliSeconds,1500,255,f);
  402. permissionToWriteToDataBase = false;
  403. break;
  404. }
  405. else{
  406. System.out.println("###Index " + f + " >>>Habe keine GPS daten...");
  407. }
  408. }else{
  409. System.out.println(">>>Index " + f + " >>>Meine Vibration wurde breits true gesetzt. Falscher Alarm");
  410. break;
  411. }
  412. }
  413. else
  414. {
  415. for(f = f; f<=indexMax; f++)
  416. {
  417. if(analyzeIfAnroidIdIsEmpty(data,f) || analyzeForOwnAndroidID(data,f))
  418. {
  419. float distanceToEarthquake;
  420. distanceToEarthquake = distance(currentLocation.getLatitude(), currentLocation.getLongitude(), Double.parseDouble(breitengradQuellVibration), Double.parseDouble(laengengradQuellVibration));
  421. long wellenAusbreitungsGeschwindigkeit = 4500; //Meter die Sekunde
  422. long delayInSeconds = (long) distanceToEarthquake/wellenAusbreitungsGeschwindigkeit; //s
  423. long delayInMilliSeconds = delayInSeconds*1000;
  424. setVibrationTimer(delayInMilliSeconds,1500,255,f);
  425. permissionToWriteToDataBase = false;
  426. break;
  427. }
  428. if(f == indexMax && !analyzeIfAnroidIdIsEmpty(data,f))
  429. {
  430. System.out.println(">>>Index " + f + " >>>Konnte keine freien Slot finden");
  431. }
  432. }
  433. }
  434. }
  435. }
  436. }
  437. public void allocateIDtoDatabaseSlot(int k)
  438. {
  439. mDatenbank = FirebaseDatabase.getInstance().getReference();
  440. mDatenbank.child("overviewnodes").child("IDG" + k).child("a_androidid").setValue(getandroidid());
  441. }
  442. public void setVibrationInDataBase(int k)
  443. {
  444. mDatenbank = FirebaseDatabase.getInstance().getReference();
  445. mDatenbank.child("overviewnodes").child("IDG" + k).child("a_androidid").setValue(getandroidid());
  446. if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
  447. mDatenbank.child("overviewnodes").child("IDG" + k).child("b_localdatetime").setValue(LocalDateTime.now().toString());
  448. }
  449. mDatenbank.child("overviewnodes").child("IDG" + k).child("c_ip").setValue(getDeviceIpAdress());
  450. if (useOwnGPS)
  451. {
  452. mDatenbank.child("overviewnodes").child("IDG" + k).child("d_breitengrad").setValue(currentLocation.getLatitude()); //aktueller Breitengrad
  453. mDatenbank.child("overviewnodes").child("IDG" + k).child("e_laengengrad").setValue(currentLocation.getLongitude()); //aktueller Längergrad
  454. }else{
  455. mDatenbank.child("overviewnodes").child("IDG" + k).child("d_breitengrad").setValue(breitengrad); //aktueller Breitengrad
  456. mDatenbank.child("overviewnodes").child("IDG" + k).child("e_laengengrad").setValue(laengengrad); //aktueller Längergrad
  457. }
  458. mDatenbank.child("overviewnodes").child("IDG" + k).child("f_nativegps").setValue(false);
  459. mDatenbank.child("overviewnodes").child("IDG" + k).child("g_vibration").setValue(true);
  460. mDatenbank.child("overviewnodes").child("IDG" + k).child("h_timestamp").setValue(Calendar.getInstance().getTimeInMillis()); //aktueller Zeitstempel wird in Datenbank eingetragen
  461. mDatenbank.child("overviewnodes").child("IDG" + k).child("i_amplitude").setValue(1000);
  462. }
  463. public String getDeviceIpAdress ()
  464. {
  465. WifiManager wm = (WifiManager) getApplicationContext().getSystemService(WIFI_SERVICE);
  466. int ip = wm.getConnectionInfo().getIpAddress();
  467. String ipAddress = String.format("%d.%d.%d.%d",(ip & 0xff),(ip >> 8 & 0xff),(ip >> 16 & 0xff), (ip >> 24 & 0xff));
  468. return ipAddress;
  469. }
  470. public String getandroidid ()
  471. {
  472. return Settings.Secure.getString(this.getContentResolver(), Settings.Secure.ANDROID_ID);
  473. }
  474. public void getDataBaseFailure (DatabaseError error)
  475. {
  476. System.out.println("Fehler");
  477. Log.w("Datenbankfehler", error.toException());
  478. }
  479. private float distance(double currentlatitude, double currentlongitude, double originLat, double originLon) {
  480. float[] results = new float[1];
  481. Location.distanceBetween(currentlatitude, currentlongitude, originLat, originLon, results);
  482. float distanceInMeters = results[0];
  483. return distanceInMeters;
  484. }
  485. //################################################################## ^^^^ DB Code ^^^^ #############################################################################
  486. //#####################################################################################################################################################################
  487. //TODO @Patrick: Ist backupVonAltemCode noch relevanter Code wenn Viration und das Schreiben in die Datenbank passt und synchron abläuft? Falls nichts relevant, können wir das ja löschen ;)
  488. public void backupVonAltemCode (DataSnapshot data)
  489. {
  490. /*
  491. //####### Auslesen für boolean-Werte #######:
  492. int i = 1;
  493. String vibrationString = data.child("overviewnodes").child("IDG").child("vibration").getValue().toString();
  494. String amplitudeString = data.child("overviewnodes").child("IDG").child("amplitude").getValue().toString();
  495. boolean vibration;
  496. if(vibrationString.equals("true")){
  497. vibration = true;
  498. }else{
  499. vibration = false;
  500. }
  501. int amplitude = Integer.parseInt(amplitudeString);
  502. // Workaround beseiteigen: hier wird immer davon ausgegangen, dass auslösendes Gerät die ID 1 besitzt
  503. if(vibration == true && i == 1)
  504. {
  505. float distance = distance(currentLocation.getLatitude(), currentLocation.getLongitude(),breitengrad,laengengrad);
  506. long delay = getTimeStampDifference(distance);
  507. setVibrationTimer(delay,1000,amplitude);
  508. }
  509. */
  510. }
  511. //TODO @Patrick: Ist getTimeStampDifference noch relevanter Code wenn Viration und das Schreiben in die Datenbank passt und synchron abläuft? Falls nichts relevant, können wir das ja löschen ;)
  512. private long getTimeStampDifference(float distance)
  513. {
  514. long diff= 0;
  515. if (distance>0)
  516. {
  517. diff = (long)Math.round(1/(EARTHQUAKE_VELOCITY/distance));
  518. }
  519. return diff;
  520. }
  521. }