Miko und Beschleunigung: funktioniert

This commit is contained in:
Franziska Bausewein 2023-06-10 15:51:25 +02:00
parent 558f48fc78
commit c931f816cd

View File

@ -75,7 +75,7 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
} }
kalibrieren = 0; kalibrieren = 0;
start_messen = false; start_messen = false;
kalibrierung_do = true; // kalibrierung_do = true;
} }
public static String getTimestamp(){ public static String getTimestamp(){
@ -220,6 +220,8 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
} }
@Override @Override
protected Void doInBackground(Long... params) { protected Void doInBackground(Long... params) {
@ -236,17 +238,6 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
boolean erlaubt_rise = true; boolean erlaubt_rise = true;
boolean erlaubt_fall = true; boolean erlaubt_fall = true;
for (; ; ) {
if (isCancelled()) {
break;
} else {
int n = recorder.read(puffer, 0, puffer.length);
Verarbeitungsergebnis ergebnis = verarbeiten(puffer, n);
anzahlVerarbeitet += n;
//kalibrierung
if(kalibrierung_do){ if(kalibrierung_do){
// Warten für 3 Sekunden // Warten für 3 Sekunden
/*long startTime = System.currentTimeMillis(); // Startzeit /*long startTime = System.currentTimeMillis(); // Startzeit
@ -256,20 +247,31 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
//3s warten auf weitere Ausführung //3s warten auf weitere Ausführung
try { try {
Thread.sleep(3000); Thread.sleep(3000);
} catch (InterruptedException e) { } catch (InterruptedException e) {
e.printStackTrace(); e.printStackTrace();
} }
//int z = recorder.read(puffer, 0, puffer.length); int anzahlIterationen = 100;
//Verarbeitungsergebnis kalibrierung = verarbeiten(puffer, z);
int anzahlIterationen = 3000;
float sum = 0; float sum = 0;
for(int i = 0; i < anzahlIterationen; i++){ for(int i = 0; i < anzahlIterationen; i++){
sum += ergebnis.db; int z = recorder.read(puffer, 0, puffer.length);
Verarbeitungsergebnis kalibrierung = verarbeiten(puffer, z);
sum += (float) kalibrierung.db;
System.out.println("Aktueller_Wert Kalibrierung" +kalibrierung.db);
} }
System.out.println("Summe:"+sum);
threshold = sum/anzahlIterationen; threshold = sum/anzahlIterationen;
kalibrierung_do = false; kalibrierung_do = false;
} }
for (; ; ) {
if (isCancelled()) {
break;
} else {
int n = recorder.read(puffer, 0, puffer.length);
Verarbeitungsergebnis ergebnis = verarbeiten(puffer, n);
anzahlVerarbeitet += n;
zaehlerZeitMessung++; zaehlerZeitMessung++;
if (zaehlerZeitMessung == maxZaehlerZeitMessung) { if (zaehlerZeitMessung == maxZaehlerZeitMessung) {
@ -324,6 +326,7 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
String status; String status;
short maxAmp = -1; short maxAmp = -1;
int db = 0; int db = 0;
int db_wert = 0;
if (n == AudioRecord.ERROR_INVALID_OPERATION) { if (n == AudioRecord.ERROR_INVALID_OPERATION) {
status = "ERROR_INVALID_OPERATION"; status = "ERROR_INVALID_OPERATION";
@ -341,7 +344,10 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
maxAmp = ringPuffer.maximum(); maxAmp = ringPuffer.maximum();
} }
//Umwandlung Amplitudenwert in dB //Umwandlung Amplitudenwert in dB
db = (int) (20*Math.log10(maxAmp)); db_wert = (int) (20*Math.log10(maxAmp));
if (db_wert > 0){
db = db_wert;
}
return new Verarbeitungsergebnis(status, maxAmp,0, db); return new Verarbeitungsergebnis(status, maxAmp,0, db);
} }
@ -468,7 +474,7 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
Daten = "Wir haben uns beim Sensor angemeldet"; Daten = "Wir haben uns beim Sensor angemeldet";
} else { } else {
Daten = "Das anmelden hat nicht geklappt"; Daten = "Das anmelden hat nicht geklappt";
} }}
SharedPreferences p = getPreferences(Context.MODE_PRIVATE); SharedPreferences p = getPreferences(Context.MODE_PRIVATE);
threshold = p.getFloat(KEY_WERT, 40); threshold = p.getFloat(KEY_WERT, 40);
kalibrierung_do = p.getBoolean(KEY_KALIBRIERUNG, true); kalibrierung_do = p.getBoolean(KEY_KALIBRIERUNG, true);
@ -480,7 +486,7 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
aufnahmeTask = new AufnahmeTask(); aufnahmeTask = new AufnahmeTask();
aufnahmeTask.execute(); aufnahmeTask.execute();
} }
}} }
@Override @Override
protected void onPause () { protected void onPause () {