Miko und Beschleunigung: funktioniert
This commit is contained in:
parent
558f48fc78
commit
c931f816cd
@ -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,7 +238,31 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
|
|||||||
boolean erlaubt_rise = true;
|
boolean erlaubt_rise = true;
|
||||||
boolean erlaubt_fall = true;
|
boolean erlaubt_fall = true;
|
||||||
|
|
||||||
|
if(kalibrierung_do){
|
||||||
|
// Warten für 3 Sekunden
|
||||||
|
/*long startTime = System.currentTimeMillis(); // Startzeit
|
||||||
|
while (System.currentTimeMillis() - startTime < 3000) {
|
||||||
|
//Warten
|
||||||
|
}*/
|
||||||
|
//3s warten auf weitere Ausführung
|
||||||
|
try {
|
||||||
|
Thread.sleep(3000);
|
||||||
|
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
int anzahlIterationen = 100;
|
||||||
|
float sum = 0;
|
||||||
|
for(int i = 0; i < anzahlIterationen; i++){
|
||||||
|
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;
|
||||||
|
kalibrierung_do = false;
|
||||||
|
}
|
||||||
|
|
||||||
for (; ; ) {
|
for (; ; ) {
|
||||||
if (isCancelled()) {
|
if (isCancelled()) {
|
||||||
@ -246,30 +272,6 @@ public class Mikrofon_Beschleunigung extends AppCompatActivity implements Sensor
|
|||||||
Verarbeitungsergebnis ergebnis = verarbeiten(puffer, n);
|
Verarbeitungsergebnis ergebnis = verarbeiten(puffer, n);
|
||||||
anzahlVerarbeitet += n;
|
anzahlVerarbeitet += n;
|
||||||
|
|
||||||
//kalibrierung
|
|
||||||
if(kalibrierung_do){
|
|
||||||
// Warten für 3 Sekunden
|
|
||||||
/*long startTime = System.currentTimeMillis(); // Startzeit
|
|
||||||
while (System.currentTimeMillis() - startTime < 3000) {
|
|
||||||
//Warten
|
|
||||||
}*/
|
|
||||||
//3s warten auf weitere Ausführung
|
|
||||||
try {
|
|
||||||
Thread.sleep(3000);
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
//int z = recorder.read(puffer, 0, puffer.length);
|
|
||||||
//Verarbeitungsergebnis kalibrierung = verarbeiten(puffer, z);
|
|
||||||
int anzahlIterationen = 3000;
|
|
||||||
float sum = 0;
|
|
||||||
for(int i = 0; i < anzahlIterationen; i++){
|
|
||||||
sum += ergebnis.db;
|
|
||||||
}
|
|
||||||
threshold = sum/anzahlIterationen;
|
|
||||||
kalibrierung_do = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
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 () {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user