Clean project for merge

This commit is contained in:
Tobias Wolz 2023-06-20 21:37:17 +02:00
parent 4381ae78f8
commit c60a14b6ac
4 changed files with 29 additions and 135 deletions

View File

@ -10,6 +10,7 @@ import android.media.AudioFormat;
import android.media.AudioRecord; import android.media.AudioRecord;
import android.media.MediaRecorder; import android.media.MediaRecorder;
import android.os.AsyncTask; import android.os.AsyncTask;
import android.util.Log;
import androidx.core.app.ActivityCompat; import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat; import androidx.core.content.ContextCompat;
@ -33,17 +34,11 @@ public class MicrophoneDetector extends Detector {
private AufnahmeTask aufnahmeTask; private AufnahmeTask aufnahmeTask;
public boolean armed = false; public boolean armed = false;
public int Schwellwert_Alarm = 100; public int Schwellwert_Alarm = 100;
GraphView graph;
Logger logger;
private Activity MainActivityForClass; private Activity MainActivityForClass;
public MicrophoneDetector(Context context, Logger MainLogger, GraphView MainGraph) { public MicrophoneDetector(Context context) {
super(context); super(context);
MainActivityForClass = (Activity) context; MainActivityForClass = (Activity) context;
logger = MainLogger; //Class uses the same logger as the MainActivity
logger.log(this.getClass().getSimpleName() + ".onCreate");
graph = MainGraph;
if (!istZugriffAufMikrofonErlaubt()) { if (!istZugriffAufMikrofonErlaubt()) {
zugriffAufMikrofonAnfordern(); zugriffAufMikrofonAnfordern();
@ -52,7 +47,6 @@ public class MicrophoneDetector extends Detector {
@Override @Override
public void startDetection() { public void startDetection() {
logger.log(this.getClass().getSimpleName() + ".startDetection");
if (!istZugriffAufMikrofonErlaubt()) { if (!istZugriffAufMikrofonErlaubt()) {
zugriffAufMikrofonAnfordern(); zugriffAufMikrofonAnfordern();
@ -65,19 +59,17 @@ public class MicrophoneDetector extends Detector {
@Override @Override
public void stopDetection() { public void stopDetection() {
logger.log(this.getClass().getSimpleName() + ".stopDetection");
if (aufnahmeTask != null) { if (aufnahmeTask != null) {
aufnahmeTask.cancel(true); aufnahmeTask.cancel(true);
// aufnahmeTask = null; // if aufnahmeTask = null, break in for loop would not work (Nullpointer Exception)
} }
} }
private boolean istZugriffAufMikrofonErlaubt() { private boolean istZugriffAufMikrofonErlaubt() {
if (ContextCompat.checkSelfPermission(MainActivityForClass, android.Manifest.permission.RECORD_AUDIO) != PackageManager.PERMISSION_GRANTED) { if (ContextCompat.checkSelfPermission(MainActivityForClass, android.Manifest.permission.RECORD_AUDIO) != PackageManager.PERMISSION_GRANTED) {
logger.log("Zugriff auf Mikrofon ist verboten."); Log.d("0","Zugriff auf Mikrofon ist verboten.");
return false; return false;
} else { } else {
logger.log("Zugriff auf Mikrofon ist erlaubt."); Log.d("0","Zugriff auf Mikrofon ist erlaubt.");
return true; return true;
} }
} }
@ -113,13 +105,8 @@ public class MicrophoneDetector extends Detector {
recorder = new AudioRecord(MediaRecorder.AudioSource.MIC, sampleRateInHz, channelConfig, audioFormat, pufferGroesseInBytes); recorder = new AudioRecord(MediaRecorder.AudioSource.MIC, sampleRateInHz, channelConfig, audioFormat, pufferGroesseInBytes);
// textViewMinPufferGroesseInBytes.setText("" + minPufferGroesseInBytes); Log.d("0","Puffergroeße: "+ minPufferGroesseInBytes + " " + pufferGroesseInBytes);
// textViewPufferGroesseInBytes.setText("" + pufferGroesseInBytes); Log.d("0","Recorder (SR, CH): "+ recorder.getSampleRate() + " " + recorder.getChannelCount());
// textViewAbtastrate.setText("" + recorder.getSampleRate());
// textViewAnzahlKanaele.setText("" + recorder.getChannelCount());
logger.log("Puffergroeße: "+ minPufferGroesseInBytes + " " + pufferGroesseInBytes);
logger.log("Recorder (SR, CH): "+ recorder.getSampleRate() + " " + recorder.getChannelCount());
int anzahlBytesProAbtastwert; int anzahlBytesProAbtastwert;
String s; String s;
@ -139,7 +126,6 @@ public class MicrophoneDetector extends Detector {
default: default:
throw new IllegalArgumentException(); throw new IllegalArgumentException();
} }
// textViewAudioFormat.setText(s);
switch (recorder.getChannelConfiguration()) { switch (recorder.getChannelConfiguration()) {
case AudioFormat.CHANNEL_IN_MONO: case AudioFormat.CHANNEL_IN_MONO:
@ -155,14 +141,12 @@ public class MicrophoneDetector extends Detector {
default: default:
throw new IllegalArgumentException(); throw new IllegalArgumentException();
} }
// textViewKanalKonfiguration.setText(s);
logger.log("Konfiguration: "+ s); Log.d("0","Konfiguration: "+ s);
int pufferGroesseInAnzahlAbtastwerten = pufferGroesseInBytes / anzahlBytesProAbtastwert; int pufferGroesseInAnzahlAbtastwerten = pufferGroesseInBytes / anzahlBytesProAbtastwert;
int pufferGroesseInMillisekunden = 1000 * pufferGroesseInAnzahlAbtastwerten / recorder.getSampleRate(); int pufferGroesseInMillisekunden = 1000 * pufferGroesseInAnzahlAbtastwerten / recorder.getSampleRate();
// textViewPufferGroesseInAnzahlAbtastwerte.setText("" + pufferGroesseInAnzahlAbtastwerten);
// textViewPufferGroesseInMillisekunden.setText("" + pufferGroesseInMillisekunden);
} }
@Override @Override
@ -178,7 +162,7 @@ public class MicrophoneDetector extends Detector {
//Kalibrierung //Kalibrierung
try { try {
Thread.sleep(3000); Thread.sleep(3000); // Time to lay down the phone
} catch (InterruptedException e) { } catch (InterruptedException e) {
e.printStackTrace(); e.printStackTrace();
} }
@ -195,20 +179,20 @@ public class MicrophoneDetector extends Detector {
} }
kalibierWert = kalibierWert/i; kalibierWert = kalibierWert/i;
// __Part of FFT__
// Complex[] zeitSignal = new Complex[puffer.length]; // Complex[] zeitSignal = new Complex[puffer.length];
// for (int j = 0; j < puffer.length; j++) { // for (int j = 0; j < puffer.length; j++) {
// zeitSignal[j] = new Complex(puffer[j], 0); // zeitSignal[j] = new Complex(puffer[j], 0);
// } // }
// Complex[] spektrum = FFT.fft(zeitSignal); // Complex[] spektrum = FFT.fft(zeitSignal);
double[] spektrum = calculateFFT(puffer); // double[] spektrum = calculateFFT(puffer);
DataPoint AddPoint; // DataPoint AddPoint;
// LineGraphSeries<DataPoint> series = new LineGraphSeries<DataPoint>(new DataPoint[]{}); // LineGraphSeries<DataPoint> series = new LineGraphSeries<DataPoint>(new DataPoint[]{});
// for (i = 0; i < spektrum.length; i++) { // for (i = 0; i < spektrum.length; i++) {
// AddPoint = new DataPoint(i, spektrum[i]); // AddPoint = new DataPoint(i, spektrum[i]);
// series.appendData(AddPoint, true, spektrum.length); // series.appendData(AddPoint, true, spektrum.length);
// } // }
// graph.addSeries(series); // graph.addSeries(series);
// logger.log(spektrum.toString());
for (; ; ) { for (; ; ) {
if (aufnahmeTask.isCancelled()) { if (aufnahmeTask.isCancelled()) {
@ -217,15 +201,14 @@ public class MicrophoneDetector extends Detector {
int n = recorder.read(puffer, 0, puffer.length); int n = recorder.read(puffer, 0, puffer.length);
Verarbeitungsergebnis ergebnis = verarbeiten(puffer, n); Verarbeitungsergebnis ergebnis = verarbeiten(puffer, n);
anzahlVerarbeitet += n; anzahlVerarbeitet += n;
// __Part of FFT__
// spektrum = calculateFFT(puffer);
// LineGraphSeries<DataPoint> newseries = new LineGraphSeries<DataPoint>(new DataPoint[]{});
// for (i = 0; i < spektrum.length; i++) {
// AddPoint = new DataPoint(i, spektrum[i]);
// newseries.appendData(AddPoint, true, spektrum.length);
// }
spektrum = calculateFFT(puffer);
LineGraphSeries<DataPoint> newseries = new LineGraphSeries<DataPoint>(new DataPoint[]{});
for (i = 0; i < spektrum.length; i++) {
AddPoint = new DataPoint(i, spektrum[i]);
newseries.appendData(AddPoint, true, spektrum.length);
}
graph.removeAllSeries();
graph.addSeries(newseries);
zaehlerZeitMessung++; zaehlerZeitMessung++;
if (zaehlerZeitMessung == maxZaehlerZeitMessung) { if (zaehlerZeitMessung == maxZaehlerZeitMessung) {
long time = System.currentTimeMillis(); long time = System.currentTimeMillis();
@ -242,7 +225,7 @@ public class MicrophoneDetector extends Detector {
publishProgress(ergebnis); publishProgress(ergebnis);
try { try {
Thread.sleep(100); Thread.sleep(10);
} catch (InterruptedException e) { } catch (InterruptedException e) {
e.printStackTrace(); e.printStackTrace();
} }
@ -265,7 +248,6 @@ public class MicrophoneDetector extends Detector {
for (int i = 0; i < n; i++) { for (int i = 0; i < n; i++) {
if (daten[i] > max) { if (daten[i] > max) {
max = daten[i]; max = daten[i];
//max = 20 * log10(abs(daten[i]) / 32768);
} }
} }
@ -282,21 +264,16 @@ public class MicrophoneDetector extends Detector {
@Override @Override
protected void onProgressUpdate(Verarbeitungsergebnis... progress) { protected void onProgressUpdate(Verarbeitungsergebnis... progress) {
super.onProgressUpdate(progress); super.onProgressUpdate(progress);
// textViewMaxAmp.setText("" + progress[0].maxAmp);
// textViewVerarbeitungsrate.setText("" + progress[0].verarbeitungsrate);
float maxAmpPrint = round(20*log10(abs(progress[0].maxAmp/1.0))); float maxAmpPrint = round(20*log10(abs(progress[0].maxAmp/1.0)));
float kalibierWertPrint = round(20*log10(abs(kalibierWert))); float kalibierWertPrint = round(20*log10(abs(kalibierWert)));
logger.overwriteLastlog("VR, Max, Kal:" + progress[0].verarbeitungsrate + ", " + maxAmpPrint Log.d("0","VR, Max, Kal:" + progress[0].verarbeitungsrate + ", " + maxAmpPrint
+ " dB, " + kalibierWertPrint + " dB"); + " dB, " + kalibierWertPrint + " dB");
if (progress[0].maxAmp >= Schwellwert_Alarm+kalibierWert && armed == true) { if (progress[0].maxAmp >= Schwellwert_Alarm+kalibierWert && armed == true) {
armed = false; armed = false;
detectionReport = new DetectionReport("Mic1", "Audio", maxAmpPrint); detectionReport = new DetectionReport("Mic1", "Audio", maxAmpPrint);
//reportViolation("Mic1", "Audio", maxAmpPrint); reportViolation("Mic1", "Audio", maxAmpPrint);
logger.log(""); Log.d("1",detectionReport.toString());
logger.log("Alarm!");
logger.log(detectionReport.toString());
logger.log("");
} }
} }
} }
@ -326,7 +303,6 @@ public class MicrophoneDetector extends Detector {
y = FFT.fft(complexSignal); y = FFT.fft(complexSignal);
mMaxFFTSample = 0.0; mMaxFFTSample = 0.0;
// mPeakPos = 0;
for(int i = 0; i < (mNumberOfFFTPoints/2); i++) for(int i = 0; i < (mNumberOfFFTPoints/2); i++)
{ {
absSignal[i] = y[i].abs(); absSignal[i] = y[i].abs();
@ -334,7 +310,6 @@ public class MicrophoneDetector extends Detector {
// if(absSignal[i] > mMaxFFTSample) // if(absSignal[i] > mMaxFFTSample)
// { // {
// mMaxFFTSample = absSignal[i]; // mMaxFFTSample = absSignal[i];
// // mPeakPos = i;
// } // }
} }

View File

@ -1,61 +0,0 @@
package com.example.ueberwachungssystem.Detector.logger;
import android.util.Log;
import android.widget.TextView;
import java.io.PrintWriter;
import java.io.StringWriter;
public class Logger {
private TextView textView;
private StringBuffer sb = new StringBuffer();
private String tag;
private int lengthOfLastLog = 0;
private boolean overwrite = false;
public Logger(String tag, TextView textView, String logInitText) {
this.tag = tag;
this.textView = textView;
sb.append(logInitText);
}
public void log(String s) {
overwrite = false;
Log.d(tag, s);
sb.append(s).append("\n");
if (textView != null) {
textView.setText(sb.toString());
}
}
public void overwriteLastlog(String s) {
Log.d(tag, s);
lengthOfLastLog = s.length();
if (overwrite)
{
sb.setLength(sb.length() - (lengthOfLastLog + 1));
}
sb.append(s).append("\n");
overwrite = true;
if (textView != null) {
textView.setText(sb.toString());
}
}
public void log(Exception e) {
StringWriter sw = new StringWriter();
e.printStackTrace(new PrintWriter(sw));
log(sw.toString());
}
public void clearLog() {
sb.setLength(0);
if (textView != null) {
textView.setText("");
}
}
public String getLoggedText() {
return sb.toString();
}
}

View File

@ -12,14 +12,10 @@ import android.widget.TextView;
import com.example.ueberwachungssystem.Detector.DetectionReport; import com.example.ueberwachungssystem.Detector.DetectionReport;
import com.example.ueberwachungssystem.Detector.Detector; import com.example.ueberwachungssystem.Detector.Detector;
import com.example.ueberwachungssystem.Detector.MicrophoneDetector; import com.example.ueberwachungssystem.Detector.MicrophoneDetector;
import com.example.ueberwachungssystem.Detector.logger.Logger;
import com.jjoe64.graphview.GraphView; import com.jjoe64.graphview.GraphView;
public class MainActivity extends AppCompatActivity { public class MainActivity extends AppCompatActivity {
Logger logger;
GraphView graph;
private TextView tv_log; private TextView tv_log;
MicrophoneDetector Mic; MicrophoneDetector Mic;
private Switch TglBtn_Mic; private Switch TglBtn_Mic;
@ -28,15 +24,13 @@ public class MainActivity extends AppCompatActivity {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); setContentView(R.layout.activity_main);
tv_log = (TextView) findViewById(R.id.tv_log); //Set textview for showing logged content tv_log = (TextView) findViewById(R.id.tv_log); //Set textview for showing logged content
logger = new Logger(this.getClass().getSimpleName(), tv_log, ""); Log.d("Main",this.getClass().getSimpleName() + ".onCreate");
logger.log(this.getClass().getSimpleName() + ".onCreate"); Mic = new MicrophoneDetector(this);
graph = (GraphView) findViewById(R.id.graph);
Mic = new MicrophoneDetector(this, logger, graph);
setupMic(); setupMic();
Mic.setOnDetectionListener(new Detector.OnDetectionListener() { Mic.setOnDetectionListener(new Detector.OnDetectionListener() {
@Override @Override
public void onDetection(@NonNull DetectionReport detectionReport) { public void onDetection(@NonNull DetectionReport detectionReport) {
Log.d("Detect", "erkannt!"); Log.d("Main", "Detection erkannt!");
} }
}); });
@ -45,13 +39,13 @@ public class MainActivity extends AppCompatActivity {
@Override @Override
public void onResume() { public void onResume() {
super.onResume(); super.onResume();
logger.log(this.getClass().getSimpleName() + ".onResume"); Log.d("Main",this.getClass().getSimpleName() + ".onResume");
} }
@Override @Override
public void onPause() { public void onPause() {
super.onPause(); super.onPause();
logger.log(this.getClass().getSimpleName() + ".onPause"); Log.d("Main",this.getClass().getSimpleName() + ".onPause");
} }
private void setupMic() { private void setupMic() {
@ -60,12 +54,11 @@ public class MainActivity extends AppCompatActivity {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
if (v == TglBtn_Mic) { if (v == TglBtn_Mic) {
logger.log("onClick toggleButtonThread " + TglBtn_Mic.isChecked()); Log.d("Main","onClick toggleButtonThread " + TglBtn_Mic.isChecked());
if (TglBtn_Mic.isChecked()) { if (TglBtn_Mic.isChecked()) {
Mic.startDetection(); Mic.startDetection();
} else { } else {
Mic.stopDetection(); Mic.stopDetection();
logger.clearLog();
} }
} }
} }

View File

@ -11,7 +11,6 @@
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:text="Log" android:text="Log"
app:layout_constraintBottom_toTopOf="@+id/graph"
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/TglBtn_Mic" /> app:layout_constraintTop_toBottomOf="@+id/TglBtn_Mic" />
@ -24,16 +23,4 @@
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent" /> app:layout_constraintTop_toTopOf="parent" />
<com.jjoe64.graphview.GraphView
android:id="@+id/graph"
android:layout_width="match_parent"
android:layout_height="200dip"
android:layout_marginStart="16dp"
android:layout_marginEnd="16dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.499" />
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>