Compare commits
No commits in common. "8a5d720685e796e9481a49d4a9688b6f7bdc411b" and "8a357e0d26e133b8361b6da9047d7dafb3583811" have entirely different histories.
8a5d720685
...
8a357e0d26
@ -9,28 +9,6 @@ import android.hardware.SensorEventListener;
|
|||||||
import android.hardware.SensorManager;
|
import android.hardware.SensorManager;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import java.util.concurrent.LinkedBlockingQueue;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Accelerometer inherits some methods from abstract Detector class (more info there)
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* USE FROM MAIN ACTIVITY:
|
|
||||||
*
|
|
||||||
* Accelerometer beschleunigungssensor = new Accelerometer(this);
|
|
||||||
* onCreate:
|
|
||||||
* //Accelerometer Setup
|
|
||||||
* beschleunigungssensor = new Accelerometer(this, logger, textViewLog); //logger and textview only for debugging necessary
|
|
||||||
* beschleunigungssensor.getSensor();
|
|
||||||
*
|
|
||||||
* //Starting Detection:
|
|
||||||
* beschleunigungssensor.startDetection();
|
|
||||||
* //Stopping Detection: also recommended at onPause to avoid unnecessary battery consumption
|
|
||||||
* beschleunigungssensor.stopDetection();
|
|
||||||
*
|
|
||||||
* */
|
|
||||||
|
|
||||||
public class Accelerometer extends Detector implements SensorEventListener {
|
public class Accelerometer extends Detector implements SensorEventListener {
|
||||||
|
|
||||||
Logger logger;
|
Logger logger;
|
||||||
@ -45,18 +23,15 @@ public class Accelerometer extends Detector implements SensorEventListener {
|
|||||||
float z;
|
float z;
|
||||||
float betrag; //Betrag aller drei Achsen sqrt(x*x + y*y + z*z)
|
float betrag; //Betrag aller drei Achsen sqrt(x*x + y*y + z*z)
|
||||||
private DetectionReport detectionReport;
|
private DetectionReport detectionReport;
|
||||||
TextView textView;
|
TextView textViewLog;
|
||||||
|
|
||||||
//Queue for taking in values
|
|
||||||
LinkedBlockingQueue<Float> linkedBlockingQueue = new LinkedBlockingQueue<>();
|
|
||||||
|
|
||||||
|
|
||||||
// In constructor pass Activity, Context and TextView from MainActivity in Accelerometer class
|
// In constructor pass Activity, Context and TextView from MainActivity in Accelerometer class
|
||||||
public Accelerometer(Context context, Logger mainLogger, TextView textView){
|
public Accelerometer(Context context, Logger mainLogger, TextView textViewLog){
|
||||||
super(context); //von Detektor
|
super(context); //von Detektor
|
||||||
logger = mainLogger;
|
logger = mainLogger;
|
||||||
this.context = context;
|
this.context = context;
|
||||||
this.textView = this.textView;
|
this.textViewLog = textViewLog;
|
||||||
//Logger logger = new Logger(this.getClass().getSimpleName(), textViewLog, "");
|
//Logger logger = new Logger(this.getClass().getSimpleName(), textViewLog, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -72,44 +47,60 @@ 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 stop() {
|
||||||
|
// unregister from the sensor to stop using it //
|
||||||
|
sensorManager.unregisterListener(this, accelerometer);
|
||||||
|
logger.log("Accelerometer unregistered!");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSensorChanged(SensorEvent event) {
|
public void onSensorChanged(SensorEvent event) {
|
||||||
try {
|
checkAlarm(event);
|
||||||
checkAlarm(event);
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
throw new RuntimeException(e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
StringBuffer stringBuffer = new StringBuffer();
|
StringBuffer stringBuffer = new StringBuffer();
|
||||||
|
public void checkAlarm (SensorEvent event) {
|
||||||
public void checkAlarm (SensorEvent event) throws InterruptedException {
|
|
||||||
x = event.values[0];
|
x = event.values[0];
|
||||||
y = event.values[1];
|
y = event.values[1];
|
||||||
z = event.values[2];
|
z = event.values[2];
|
||||||
betrag = (float) sqrt(x*x + y*y + z*z);
|
betrag = (float) sqrt(x*x + y*y + z*z);
|
||||||
float threshold = 1.5F;
|
double schwelle = 1.5;
|
||||||
|
|
||||||
if (!alarm) {
|
if (!alarm) {
|
||||||
if (betrag > threshold) {
|
if (betrag > schwelle) {
|
||||||
|
stringBuffer.append("\n Betragswert über Schwelle, Detection Report wird gleich aufgerufen");
|
||||||
|
//logger.log("Betragswert über Schwelle erkannt, Alarm wird gleich angeschaltet");
|
||||||
alarm = true;
|
alarm = true;
|
||||||
|
stringBuffer.append("\nAlarm = " + alarm);
|
||||||
detectionReport = new DetectionReport("Accelerometer1", "Bewegung", betrag);
|
detectionReport = new DetectionReport("Accelerometer1", "Bewegung", betrag);
|
||||||
|
stringBuffer.append("\nDetectionReport = " + detectionReport)
|
||||||
stringBuffer.append("\nDetectionReport = ").append(detectionReport).append("\nAlarm an");
|
.append("\nAlarm an" + betrag + event.timestamp);
|
||||||
|
//logger.log("Alarm an");
|
||||||
|
//logger.log("Betrag: " + betrag + event.timestamp);
|
||||||
logger.clearLog();
|
logger.clearLog();
|
||||||
logger.log(stringBuffer.toString());
|
logger.log(stringBuffer.toString());
|
||||||
stringBuffer.delete(0, stringBuffer.length());
|
stringBuffer.delete(0, stringBuffer.length());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (betrag < threshold) {
|
if (betrag < schwelle) {
|
||||||
stringBuffer.append("\nAlarm noch an; Neuer Betragswert unter Schwellwert:").append(betrag);
|
stringBuffer.append("\nAlarm noch an; Neuer Betragswert unter Schwellwert:" + betrag);
|
||||||
//logger.log("Alarm ist noch an; Neuer Betragswert unter Schwellwert: " + betrag);
|
//logger.log("Alarm ist noch an; Neuer Betragswert unter Schwellwert: " + betrag);
|
||||||
alarm = false;
|
alarm = false;
|
||||||
//logger.log("Alarm" + alarm);
|
//logger.log("Alarm" + alarm);
|
||||||
//logger.log("Alarm wieder ausgeschaltet");
|
//logger.log("Alarm wieder ausgeschaltet");
|
||||||
stringBuffer.append("\nAlarm = ").append(alarm);
|
stringBuffer.append("\nAlarm = " + alarm);
|
||||||
} else {
|
} else {
|
||||||
logger.log("Betragswert immer noch über Schwellwert: " + betrag + "; Alarm bleibt an.");
|
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.clearLog();
|
||||||
logger.log(stringBuffer.toString());
|
logger.log(stringBuffer.toString());
|
||||||
|
@ -16,11 +16,18 @@ import android.widget.ToggleButton;
|
|||||||
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
|
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
|
||||||
|
|
||||||
private Logger logger;
|
private Logger logger;
|
||||||
|
private Context context;
|
||||||
private Accelerometer beschleunigungssensor;
|
private Accelerometer beschleunigungssensor;
|
||||||
|
//private ThreadDemo threadDemo;
|
||||||
private TextView textViewLog;
|
private TextView textViewLog;
|
||||||
private Button button1;
|
private Button button1;
|
||||||
|
private TextView textViewWorkerThread;
|
||||||
|
SensorEvent event;
|
||||||
|
|
||||||
ToggleButton toggleButton1;
|
ToggleButton toggleButton1;
|
||||||
|
|
||||||
|
boolean currentAlarm;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
@ -28,19 +35,20 @@ public class MainActivity extends AppCompatActivity implements View.OnClickListe
|
|||||||
setContentView(R.layout.activity_main);
|
setContentView(R.layout.activity_main);
|
||||||
|
|
||||||
// Logger setup
|
// Logger setup
|
||||||
textViewLog = findViewById(R.id.textViewLog);
|
textViewLog = (TextView) findViewById(R.id.textViewLog);
|
||||||
textViewLog.setMovementMethod(new ScrollingMovementMethod());
|
|
||||||
logger = new Logger(this.getClass().getSimpleName(), textViewLog, "");
|
logger = new Logger(this.getClass().getSimpleName(), textViewLog, "");
|
||||||
|
|
||||||
toggleButton1 = findViewById(R.id.toggleButton1); //togglebutton um Detektion zu steuern
|
toggleButton1 = (ToggleButton) findViewById(R.id.toggleButton1); //togglebutton um Thread zu steuern
|
||||||
toggleButton1.setOnClickListener(this);
|
toggleButton1.setOnClickListener(this);
|
||||||
|
textViewWorkerThread = (TextView) findViewById(R.id.textViewWorkerThread); //TextView um Thread zu überwachen
|
||||||
|
textViewWorkerThread.setMovementMethod(new ScrollingMovementMethod());
|
||||||
|
|
||||||
//Button to clear Log while Debugging
|
//Button to clear Log while Debugging
|
||||||
button1 = (Button) findViewById(R.id.button1);
|
button1 = (Button) findViewById(R.id.button1);
|
||||||
button1.setOnClickListener(this);
|
button1.setOnClickListener(this);
|
||||||
|
|
||||||
//Accelerometer Setup
|
//Accelerometer Setup
|
||||||
beschleunigungssensor = new Accelerometer(this, logger, textViewLog); //logger and textview only for debugging necessary
|
beschleunigungssensor = new Accelerometer(this, logger, textViewWorkerThread);
|
||||||
beschleunigungssensor.getSensor();
|
beschleunigungssensor.getSensor();
|
||||||
|
|
||||||
logger.log("onCreate");
|
logger.log("onCreate");
|
||||||
@ -71,7 +79,7 @@ public class MainActivity extends AppCompatActivity implements View.OnClickListe
|
|||||||
logger.log("Detection stopped");
|
logger.log("Detection stopped");
|
||||||
}
|
}
|
||||||
} else if (v == button1) {
|
} else if (v == button1) {
|
||||||
logger.clearLog(); //just to clear log manually if it's too full
|
logger.clearLog();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,63 +0,0 @@
|
|||||||
package com.example.ueberwachungssystem;
|
|
||||||
|
|
||||||
import androidx.appcompat.app.AppCompatActivity;
|
|
||||||
|
|
||||||
import java.util.concurrent.LinkedBlockingQueue;
|
|
||||||
|
|
||||||
public class SensorValueThread implements Runnable {
|
|
||||||
|
|
||||||
private volatile boolean running = false;
|
|
||||||
private Thread thread;
|
|
||||||
private String threadname = "sensorValueThread";
|
|
||||||
Logger logger;
|
|
||||||
float x;
|
|
||||||
LinkedBlockingQueue<Float> linkedBlockingQueue;
|
|
||||||
//AppCompatActivity activity;
|
|
||||||
|
|
||||||
//Constructor muss die LinkedBlockingQueue übergeben bekommen
|
|
||||||
public SensorValueThread(LinkedBlockingQueue linkedBlockingQueue){
|
|
||||||
this.linkedBlockingQueue = linkedBlockingQueue;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
while (running){
|
|
||||||
//Code to execute while running == true, i.e. reading queue and calculate sth.
|
|
||||||
try {
|
|
||||||
x = linkedBlockingQueue.take();
|
|
||||||
|
|
||||||
Thread.sleep(100);
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void start() {
|
|
||||||
logger.log("Starting " + threadname + "...");
|
|
||||||
running = true;
|
|
||||||
thread = new Thread(this);
|
|
||||||
thread.setName(threadname);
|
|
||||||
thread.start();
|
|
||||||
logger.log("..." + threadname + " started");
|
|
||||||
}
|
|
||||||
|
|
||||||
void stop() {
|
|
||||||
if (!running) {
|
|
||||||
logger.log(threadname + " not running");
|
|
||||||
} else {
|
|
||||||
logger.log("Stopping " + threadname + "...");
|
|
||||||
running = false;
|
|
||||||
while(true){
|
|
||||||
try {
|
|
||||||
thread.join();
|
|
||||||
logger.log("... " + threadname + " stopped");
|
|
||||||
break;
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user