|
|
@@ -9,6 +9,8 @@ import android.hardware.SensorEventListener; |
|
|
|
import android.hardware.SensorManager; |
|
|
|
import android.widget.TextView; |
|
|
|
|
|
|
|
import java.util.concurrent.LinkedBlockingQueue; |
|
|
|
|
|
|
|
public class Accelerometer extends Detector implements SensorEventListener { |
|
|
|
|
|
|
|
Logger logger; |
|
|
@@ -25,6 +27,9 @@ public class Accelerometer extends Detector implements SensorEventListener { |
|
|
|
private DetectionReport detectionReport; |
|
|
|
TextView textViewLog; |
|
|
|
|
|
|
|
//Queue for taking in values |
|
|
|
LinkedBlockingQueue<Float> linkedBlockingQueue = new LinkedBlockingQueue<>(); |
|
|
|
|
|
|
|
|
|
|
|
// In constructor pass Activity, Context and TextView from MainActivity in Accelerometer class |
|
|
|
public Accelerometer(Context context, Logger mainLogger, TextView textViewLog){ |
|
|
@@ -48,59 +53,58 @@ public class Accelerometer extends Detector implements SensorEventListener { |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void start() { |
|
|
|
// register the sensor before using // |
|
|
|
sensorManager.registerListener(this, accelerometer, SensorManager.SENSOR_DELAY_NORMAL); |
|
|
|
logger.log("Accelerometer, start!"); |
|
|
|
} |
|
|
|
|
|
|
|
// void start wird überflüssig mit void startDetection() |
|
|
|
//void start() { |
|
|
|
// // register the sensor before using // |
|
|
|
// sensorManager.registerListener(this, accelerometer, SensorManager.SENSOR_DELAY_NORMAL); |
|
|
|
// logger.log("Accelerometer, registered"); |
|
|
|
//} |
|
|
|
|
|
|
|
void stop() { |
|
|
|
// unregister from the sensor to stop using it // |
|
|
|
sensorManager.unregisterListener(this, accelerometer); |
|
|
|
logger.log("Accelerometer unregistered!"); |
|
|
|
} |
|
|
|
// void stop wird überflüssig mit void stopDetection() |
|
|
|
//void stop() { |
|
|
|
// // unregister from the sensor to stop using it // |
|
|
|
// sensorManager.unregisterListener(this, accelerometer); |
|
|
|
// logger.log("Accelerometer unregistered!"); |
|
|
|
//} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
public void onSensorChanged(SensorEvent event) { |
|
|
|
checkAlarm(event); |
|
|
|
try { |
|
|
|
checkAlarm(event); |
|
|
|
} catch (InterruptedException e) { |
|
|
|
throw new RuntimeException(e); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
StringBuffer stringBuffer = new StringBuffer(); |
|
|
|
public void checkAlarm (SensorEvent event) { |
|
|
|
public void checkAlarm (SensorEvent event) throws InterruptedException { |
|
|
|
x = event.values[0]; |
|
|
|
y = event.values[1]; |
|
|
|
z = event.values[2]; |
|
|
|
betrag = (float) sqrt(x*x + y*y + z*z); |
|
|
|
double schwelle = 1.5; |
|
|
|
float threshold = 1.5F; |
|
|
|
|
|
|
|
if (!alarm) { |
|
|
|
if (betrag > schwelle) { |
|
|
|
stringBuffer.append("\n Betragswert über Schwelle, Detection Report wird gleich aufgerufen"); |
|
|
|
//logger.log("Betragswert über Schwelle erkannt, Alarm wird gleich angeschaltet"); |
|
|
|
if (betrag > threshold) { |
|
|
|
alarm = true; |
|
|
|
stringBuffer.append("\nAlarm = " + alarm); |
|
|
|
detectionReport = new DetectionReport("Accelerometer1", "Bewegung", betrag); |
|
|
|
stringBuffer.append("\nDetectionReport = " + detectionReport) |
|
|
|
.append("\nAlarm an" + betrag + event.timestamp); |
|
|
|
//logger.log("Alarm an"); |
|
|
|
//logger.log("Betrag: " + betrag + event.timestamp); |
|
|
|
stringBuffer.append("\nDetectionReport = ").append(detectionReport).append("\nAlarm an").append(betrag).append(event.timestamp); |
|
|
|
linkedBlockingQueue.put(betrag); |
|
|
|
logger.clearLog(); |
|
|
|
logger.log(stringBuffer.toString()); |
|
|
|
stringBuffer.delete(0, stringBuffer.length()); |
|
|
|
} |
|
|
|
} else { |
|
|
|
if (betrag < schwelle) { |
|
|
|
stringBuffer.append("\nAlarm noch an; Neuer Betragswert unter Schwellwert:" + betrag); |
|
|
|
if (betrag < threshold) { |
|
|
|
stringBuffer.append("\nAlarm noch an; Neuer Betragswert unter Schwellwert:").append(betrag); |
|
|
|
//logger.log("Alarm ist noch an; Neuer Betragswert unter Schwellwert: " + betrag); |
|
|
|
alarm = false; |
|
|
|
//logger.log("Alarm" + alarm); |
|
|
|
//logger.log("Alarm wieder ausgeschaltet"); |
|
|
|
stringBuffer.append("\nAlarm = " + alarm); |
|
|
|
stringBuffer.append("\nAlarm = ").append(alarm); |
|
|
|
} else { |
|
|
|
logger.log("Betragswert immer noch über Schwellwert: " + betrag + "; Alarm bleibt an."); |
|
|
|
logger.log("Betragswert immer noch über Schwellwert: " + betrag + "; Alarm bleibt an."); |
|
|
|
} |
|
|
|
//logger.clearLog(); |
|
|
|
logger.log(stringBuffer.toString()); |