In diesem Abschnitt werden Sensorachsen, Basissensoren und zusammengesetzte Sensoren (Aktivität, Haltung, nicht kalibrierte und Interaktion) beschrieben.
Sensorachsen
Sensorereigniswerte vieler Sensoren werden in einem bestimmten Frame ausgedrückt, der relativ zum Gerät statisch ist.
Achsen für Mobilgeräte
Die Sensor API ist nur relativ zur natürlichen Ausrichtung des Displays. Die Achsen werden nicht vertauscht, wenn sich die Displayausrichtung des Geräts ändert.
Achsen für die Automobilbranche
In Android Automotive-Implementierungen werden Achsen in Bezug auf den Fahrzeugkörper definiert. Der Ursprung des Fahrzeugreferenzrahmens ist die Mitte der Hinterachse. Der Referenzrahmen des Fahrzeugs ist so ausgerichtet, dass:
- Die X-Achse zeigt nach rechts und liegt in einer horizontalen Ebene, die senkrecht zur Symmetrieebene des Fahrzeugs steht.
- Die Y-Achse zeigt nach vorne und befindet sich in einer horizontalen Ebene.
Der Fahrzeugreferenzrahmen ist ein rechtshändiges Koordinatensystem. Die Z‑Achse zeigt also nach oben.
Die Z‑Achse des Referenzsystems ist an der Schwerkraft ausgerichtet, d. h., die X‑ und Y‑Achse sind beide horizontal. Daher verläuft die Y-Achse möglicherweise nicht immer durch die Vorderachse.
Basissensoren
Basissensortypen sind nach den physischen Sensoren benannt, die sie repräsentieren. Diese Sensoren leiten Daten von einem einzelnen physischen Sensor weiter, im Gegensatz zu Kompositsensoren, die Daten aus anderen Sensoren generieren. Beispiele für Basissensortypen:
SENSOR_TYPE_ACCELEROMETER
SENSOR_TYPE_GYROSCOPE
SENSOR_TYPE_MAGNETOMETER
Basissensoren sind jedoch nicht mit dem zugrunde liegenden physischen Sensor identisch und sollten nicht mit diesem verwechselt werden. Die Daten eines Basissensors sind nicht die Rohausgabe des physischen Sensors, da Korrekturen wie Vorzeichenkorrektur und Temperaturkompensation angewendet werden.
In den folgenden Anwendungsfällen können sich die Eigenschaften eines Basissensors beispielsweise von den Eigenschaften des zugrunde liegenden physischen Sensors unterscheiden:
- Ein Gyroskopchip mit einem Bias-Bereich von 1 Grad/Sek.
- Nach der Kalibrierung in der Fabrik, der Temperatur- und der Vorzeichenkorrektur wird die tatsächliche Vorzeichenabweichung des Android-Sensors reduziert, möglicherweise bis zu einem Punkt, an dem die Vorzeichenabweichung garantiert unter 0,01 Grad pro Sekunde liegt.
- In diesem Fall wird davon ausgegangen, dass der Android-Sensor eine Abweichung von unter 0,01 Grad pro Sekunde hat, obwohl in den Datenblättern des zugrunde liegenden Sensors 1 Grad pro Sekunde angegeben ist.
- Ein Barometer mit einer Leistungsaufnahme von 100 µW.
- Da die generierten Daten vom Chip zum SoC übertragen werden müssen, sind die tatsächlichen Energiekosten für die Erhebung von Daten über den Barometer-Android-Sensor möglicherweise viel höher, z. B. 1.000 µW.
- In diesem Fall wird der Android-Sensor mit einem Energieverbrauch von 1.000 µW angegeben, obwohl der an den Barometer-Chip-Leitungen gemessene Energieverbrauch 100 µW beträgt.
- Ein Magnetometer, das bei der Kalibrierung 100 µW verbraucht, aber bei der Kalibrierung mehr.
- Für die Kalibrierung muss möglicherweise das Gyroskop aktiviert werden, was 5.000 µW verbraucht, und ein Algorithmus ausgeführt werden, was weitere 900 µW kostet.
- In diesem Fall beträgt die maximale Leistungsaufnahme des Android-Magnetometers 6.000 µW.
- In diesem Fall ist der durchschnittliche Energieverbrauch der nützlichere Messwert. Er wird in den statischen Eigenschaften des Sensors über die HAL erfasst.
Beschleunigungsmesser
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_ACCELEROMETER)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Beschleunigungsmesser erfasst die Beschleunigung des Geräts entlang der drei Sensorachsen. Die gemessene Beschleunigung umfasst sowohl die physikalische Beschleunigung (Geschwindigkeitsänderung) als auch die Schwerkraft. Die Messung wird in den Feldern „x“, „y“ und „z“ von „sensors_event_t.acceleration“ erfasst.
Alle Werte sind in SI-Einheiten (m/s²) angegeben und geben die Beschleunigung des Geräts abzüglich der Schwerkraft entlang der drei Sensorachsen an.
Beispiele:
- Die Norm von (x, y, z) sollte im freien Fall nahe bei 0 liegen.
- Wenn das Gerät flach auf einem Tisch liegt und auf der linken Seite nach rechts gedrückt wird, ist der Wert für die X‑Beschleunigung positiv.
- Wenn das Gerät flach auf einem Tisch liegt, beträgt der Beschleunigungswert entlang der Z‑Achse +9,81 alo. Dies entspricht der Beschleunigung des Geräts (0 m/s²) abzüglich der Schwerkraft (–9,81 m/s²).
- Wenn das Gerät flach auf einem Tisch liegt und nach oben gedrückt wird, ist der Beschleunigungswert größer als +9,81. Dies entspricht der Beschleunigung des Geräts (+A m/s²) abzüglich der Schwerkraft (–9,81 m/s²).
Die Messungen werden mithilfe der folgenden Methoden kalibriert:
- Temperaturkompensation
- Online-Voreingenommenheitskalibrierung
- Online-Kalibrierung der Waage
Die Kalibrierung von Offset und Skala muss nur aktualisiert werden, während der Sensor deaktiviert ist, um während des Streamings keine Wertesprünge zu verursachen.
Der Beschleunigungsmesser gibt auch über sensors_event_t.acceleration.status
an, wie genau die Messwerte voraussichtlich sind. Weitere Informationen zu den möglichen Werten für dieses Feld finden Sie in den Konstanten
SENSOR_STATUS_*
von
SensorManager
.
Umgebungstemperatur
Berichtsmodus: Bei Änderung
getDefaultSensor(SENSOR_TYPE_AMBIENT_TEMPERATURE)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Dieser Sensor liefert die Umgebungstemperatur (Raumtemperatur) in Grad Celsius.
Magnetfeldsensor
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_MAGNETIC_FIELD)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
SENSOR_TYPE_GEOMAGNETIC_FIELD == SENSOR_TYPE_MAGNETIC_FIELD
Ein Magnetfeldsensor (auch als Magnetometer bezeichnet) gibt das Magnetfeld der Umgebung an, gemessen entlang der drei Sensorachsen.
Die Messung wird in den Feldern „x“, „y“ und „z“ von sensors_event_t.magnetic
angegeben. Alle Werte sind in Mikrotesla (µT).
Über sensors_event_t.magnetic.status
gibt das Magnetometer auch an, wie genau die Messwerte voraussichtlich sind. Weitere Informationen zu den möglichen Werten für dieses Feld finden Sie in den Konstanten
SENSOR_STATUS_*
von
SensorManager
.
Die Messungen werden mithilfe der folgenden Methoden kalibriert:
- Temperaturkompensation
- Kalibrierung des Weicheisens in der Fabrik (oder online)
- Online-Kalibrierung für hartes Eisen
Gyroskop
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_GYROSCOPE)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Gyroskopsensor meldet die Drehgeschwindigkeit des Geräts um die drei Sensorachsen.
Eine positive Drehung ist gegen den Uhrzeigersinn (Rechtshänderregel). Das heißt, ein Beobachter, der von einem positiven Ort auf der X-, Y- oder Z-Achse auf ein Gerät blickt, das sich am Ursprung befindet, würde eine positive Drehung melden, wenn sich das Gerät scheinbar gegen den Uhrzeigersinn dreht. Hinweis: Dies ist die standardmäßige mathematische Definition der positiven Drehung und stimmt nicht mit der Definition von Roll in der Luft- und Raumfahrt überein.
Die Messung wird in den Feldern „x“, „y“ und „z“ von sensors_event_t.gyro
erfasst. Alle Werte sind in Radian pro Sekunde (rad/s) angegeben.
Die Messungen werden mithilfe der folgenden Methoden kalibriert:
- Temperaturkompensation
- Kalibrierung in der Fabrik (oder online)
- Online-Voreinstellbare Kalibrierung (zur Entfernung von Abweichungen)
Das Gyroskop gibt auch über sensors_event_t.gyro.status
an, wie genau seine Messwerte voraussichtlich sind. Weitere Informationen zu den möglichen Werten für dieses Feld finden Sie in den Konstanten
SENSOR_STATUS_*
von
SensorManager
.
Das Gyroskop kann nicht anhand von Magnetometern und Beschleunigungsmessern emuliert werden, da dies zu einer geringeren lokalen Konsistenz und Reaktionsfähigkeit führen würde. Er muss auf einem herkömmlichen Gyroskopchip basieren.
Herzfrequenz
Berichtsmodus: Bei Änderung
getDefaultSensor(SENSOR_TYPE_HEART_RATE)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Herzfrequenzsensor erfasst die aktuelle Herzfrequenz der Person, die das Gerät berührt.
Die aktuelle Herzfrequenz in Schlägen pro Minute (SPM) wird unter sensors_event_t.heart_rate.bpm
angezeigt und der Status des Sensors unter sensors_event_t.heart_rate.status
. Weitere Informationen zu den möglichen Werten für dieses Feld finden Sie in den Konstanten
SENSOR_STATUS_*
von
SensorManager
. Insbesondere bei der ersten Aktivierung muss das Statusfeld des ersten Ereignisses auf SENSOR_STATUS_UNRELIABLE
gesetzt sein, es sei denn, das Gerät befindet sich nicht am Körper. Da dieser Sensor auf „Bei Änderung“ eingestellt ist, werden Ereignisse nur dann generiert, wenn sich heart_rate.bpm
oder heart_rate.status
seit dem letzten Ereignis geändert haben. Die Ereignisse werden nicht schneller als alle sampling_period
generiert.
sensor_t.requiredPermission
ist immer SENSOR_PERMISSION_BODY_SENSORS
.
Leicht
Berichtsmodus: Bei Änderung
getDefaultSensor(SENSOR_TYPE_LIGHT)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Lichtsensor meldet die aktuelle Beleuchtung in SI-Lux-Einheiten.
Die Messung wird in sensors_event_t.light
erfasst.
Näherung
Berichtsmodus: Bei Änderung
Wird in der Regel als Wecksensor definiert
getDefaultSensor(SENSOR_TYPE_PROXIMITY)
gibt einen Wecksensor zurück
Ein Näherungssensor meldet die Entfernung vom Sensor zur nächstgelegenen sichtbaren Oberfläche.
Bis Android 4.4 waren die Näherungssensoren immer Wecksensoren, die das SoC bei einer Änderung der Nähe weckten. Nach Android 4.4 empfehlen wir, zuerst die Weckversion dieses Sensors zu implementieren, da sie zum Ein- und Ausschalten des Displays während eines Anrufs verwendet wird.
Die Messung wird in sensors_event_t.distance
in Zentimetern angegeben. Einige Näherungssensoren unterstützen nur eine binäre Messung („Nah“ oder „Weit“).
In diesem Fall meldet der Sensor den Wert sensor_t.maxRange
im Status „Weit“ und einen Wert unter sensor_t.maxRange
im Status „Nah“.
Luftdruck
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_PRESSURE)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Drucksensor (auch Barometer genannt) gibt den atmosphärischen Druck in Hektopascal (hPa) an.
Die Messungen werden mithilfe von
- Temperaturkompensation
- Kalibrierung der Vorspannung
- Kalibrierung im Werk
Das Barometer wird häufig verwendet, um Höhenänderungen zu schätzen. Zur Schätzung der absoluten Höhe muss der Druck auf Meereshöhe (der sich je nach Wetter ändert) als Referenz verwendet werden.
Relative Luftfeuchtigkeit
Berichtsmodus: Bei Änderung
getDefaultSensor(SENSOR_TYPE_RELATIVE_HUMIDITY)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Sensor für die relative Luftfeuchtigkeit misst die relative Luftfeuchtigkeit der Umgebung und gibt einen Wert in Prozent zurück.
Zusammengesetzte Sensortypen
Ein Kompositsensor generiert Daten durch Verarbeitung und/oder Zusammenführen von Daten aus einem oder mehreren physischen Sensoren. Alle Sensoren, die keine Basissensoren sind, werden als zusammengesetzte Sensoren bezeichnet. Beispiele für Kompositsensoren:
- Schrittzähler und erhebliche Bewegung, die in der Regel auf einem Beschleunigungsmesser basieren, aber auch auf anderen Sensoren, wenn Stromverbrauch und Genauigkeit akzeptabel sind.
- Spieldrehungsvektor, basierend auf einem Beschleunigungsmesser und einem Gyroskop.
- Nicht kalibriertes Gyroskop, das dem Gyroskop im Unterbau ähnelt, bei dem die Kalibrierung der Abweichung jedoch separat erfasst wird, anstatt bei der Messung korrigiert zu werden.
Wie bei Basissensoren stammen die Eigenschaften der zusammengesetzten Sensoren aus den Eigenschaften der Enddaten. Die Leistungsaufnahme eines Rotationsvektors für Spiele entspricht beispielsweise wahrscheinlich der Summe der Leistungsaufnahmen des Beschleunigungsmesser-Chips, des Gyroskop-Chips, des Chips zur Datenverarbeitung und der Busse, die die Daten transportieren. Als weiteres Beispiel: Die Abweichung eines Drehvektors in einem Spiel hängt ebenso von der Qualität des Kalibrierungsalgorithmus wie von den physischen Sensoreigenschaften ab.
In der folgenden Tabelle sind die verfügbaren Typen von Kompositsensoren aufgeführt. Jeder zusammengesetzte Sensor basiert auf Daten von einem oder mehreren physischen Sensoren. Wählen Sie keine anderen zugrunde liegenden physischen Sensoren aus, um Ergebnisse zu approximieren, da dies die Nutzerfreundlichkeit beeinträchtigt.
Sensortyp | Kategorie | Zugrunde liegende physische Sensoren | Berichtsmodus |
---|---|---|---|
Einstellung |
Beschleunigungsmesser, Gyroskop, KEIN MAGNETOMETER VERWENDEN |
Kontinuierlich |
|
Einstellung |
Beschleunigungsmesser, Magnetometer, KEIN Gyroskop verwenden |
Kontinuierlich |
|
Glance-Geste | Interaktion |
Nicht definiert |
One-Shot |
Einstellung |
Beschleunigungsmesser, Gyroskop (falls vorhanden) oder Magnetometer (falls kein Gyroskop vorhanden) |
Kontinuierlich |
|
Nicht kalibriert |
Gyroskop |
Kontinuierlich |
|
Aktivität |
Beschleunigungsmesser, Gyroskop (falls vorhanden) oder Magnetometer (falls kein Gyroskop vorhanden) |
Kontinuierlich |
|
Nicht kalibriert |
Magnetometer |
Kontinuierlich |
|
Ausrichtung (eingestellt) |
Einstellung |
Beschleunigungsmesser, Magnetometer, Gyroskop (falls vorhanden) |
Kontinuierlich |
Interaktion |
Nicht definiert |
One-Shot |
|
Einstellung |
Beschleunigungsmesser, Magnetometer, Gyroskop |
Kontinuierlich |
|
Aktivität |
Beschleunigungsmesser (oder ein anderer Sensor, solange er sehr sparsam ist) |
One-Shot |
|
Aktivität |
Beschleunigungsmesser |
On-change |
|
Aktivität |
Beschleunigungsmesser |
Specials |
|
Aktivität |
Beschleunigungsmesser |
Specials |
|
Interaktion |
Nicht definiert |
One-Shot |
= Energiesparsensor
Kompositsensoren für Aktivitäten
Lineare Beschleunigung
Zugrunde liegende physische Sensoren: Beschleunigungsmesser und (falls vorhanden) Gyroskop (oder Magnetometer, falls kein Gyroskop vorhanden ist)
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_LINEAR_ACCELERATION)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein linearer Beschleunigungssensor erfasst die lineare Beschleunigung des Geräts im Sensorrahmen, ohne Schwerkraft.
Die Ausgabe ist konzeptionell: Ausgabe des Beschleunigungsmessers abzüglich der Ausgabe des Schwerekraftsensors. Er wird in den Feldern „x“, „y“ und „z“ von sensors_event_t.acceleration
in m/s² angegeben.
Die Messwerte auf allen Achsen sollten nahe bei 0 liegen, wenn sich das Gerät nicht bewegt.
Wenn das Gerät ein Gyroskop hat, muss der lineare Beschleunigungssensor das Gyroskop und den Beschleunigungsmesser als Eingabe verwenden.
Wenn das Gerät kein Gyroskop hat, müssen der lineare Beschleunigungssensor den Beschleunigungsmesser und das Magnetometer als Eingabe verwenden.
Starke Bewegung
Untergeordneter physischer Sensor: Beschleunigungsmesser (oder ein anderer, solange er einen niedrigen Energieverbrauch hat)
Berichtsmodus: One-Shot
Niedriger Energieverbrauch
Implementieren Sie nur die Weckversion dieses Sensors.
getDefaultSensor(SENSOR_TYPE_SIGNIFICANT_MOTION)
gibt einen Wecksensor zurück
Ein Bewegungsmelder für wichtige Bewegungen wird ausgelöst, wenn eine erhebliche Bewegung erkannt wird, also eine Bewegung, die zu einer Änderung des Nutzerstandorts führen könnte.
Beispiele für solche wichtigen Anträge:
- Zu Fuß oder mit dem Fahrrad
- Sitzen in einem fahrenden Auto, Bus oder Zug
Beispiele für Situationen, in denen keine erhebliche Bewegung ausgelöst wird:
- Smartphone in der Tasche und die Person bewegt sich nicht
- Das Smartphone liegt auf einem Tisch, der aufgrund von Verkehr oder einer Waschmaschine in der Nähe etwas wackelt
Der Bewegungsmelder wird verwendet, um den Stromverbrauch bei der Standortbestimmung zu senken. Wenn die Lokalisierungsalgorithmen erkennen, dass sich das Gerät nicht bewegt, können sie in einen Energiesparmodus wechseln, bei dem das Gerät nur bei starken Bewegungen aktiviert wird, wenn sich der Nutzer an einen anderen Ort bewegt.
Dieser Sensor muss einen geringen Energieverbrauch haben. Es gibt einen Kompromiss beim Stromverbrauch, der zu einer kleinen Anzahl von falsch negativen Ergebnissen führen kann. Das hat mehrere Gründe:
- Mit diesem Sensor soll Strom gespart werden.
- Das Auslösen eines Ereignisses, wenn sich der Nutzer nicht bewegt (falsch positiv), ist energieintensiv und sollte vermieden werden.
- Es ist akzeptabel, wenn kein Ereignis ausgelöst wird, wenn sich der Nutzer bewegt (falsch negativ), solange dies nicht wiederholt geschieht. Wenn der Nutzer seit 10 Sekunden geht, darf innerhalb dieser 10 Sekunden kein Ereignis ausgelöst werden.
Für jedes Sensorereignis wird 1
in sensors_event_t.data[0]
erfasst.
Schrittmelder
Untergeordneter physischer Sensor: Beschleunigungsmesser (+ ggf. andere, solange sie einen niedrigen Energieverbrauch haben)
Berichtsmodus: Speziell (ein Ereignis pro ausgeführtem Schritt)
Niedriger Energieverbrauch
getDefaultSensor(SENSOR_TYPE_STEP_DETECTOR)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Schrittzähler generiert jedes Mal ein Ereignis, wenn der Nutzer einen Schritt macht.
Der Zeitstempel des Ereignisses sensors_event_t.timestamp
entspricht dem Zeitpunkt, an dem der Fuß den Boden berührt, was zu einer großen Abweichung bei der Beschleunigung führt.
Im Vergleich zum Schrittzähler sollte der Schrittmesser eine geringere Latenz haben (weniger als zwei Sekunden). Sowohl der Schrittzähler als auch der Schrittzähler erkennen, wenn der Nutzer geht, läuft und Treppen steigt. Sie sollten nicht ausgelöst werden, wenn der Nutzer Fahrrad fährt, Auto fährt oder sich in anderen Fahrzeugen befindet.
Dieser Sensor muss einen geringen Energieverbrauch haben. Wenn die Schritterkennung also nicht in der Hardware erfolgen kann, sollte dieser Sensor nicht definiert werden. Insbesondere wenn der Schrittzähler aktiviert und der Beschleunigungsmesser deaktiviert ist, sollten nur Schritte Unterbrechungen auslösen (nicht jede Beschleunigungsmessermessung).
sampling_period_ns
hat keine Auswirkungen auf Schrittzähler.
Für jedes Sensorereignis wird 1
in sensors_event_t.data[0]
erfasst.
Schrittzähler
Untergeordneter physischer Sensor: Beschleunigungsmesser (+ ggf. andere, solange sie einen niedrigen Energieverbrauch haben)
Berichtsmodus: Bei Änderung
Niedriger Energieverbrauch
getDefaultSensor(SENSOR_TYPE_STEP_COUNTER)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Schrittzähler gibt die Anzahl der Schritte an, die der Nutzer seit dem letzten Neustart zurückgelegt hat, während die Funktion aktiviert war.
Die Messung wird in sensors_event_t.step_counter
als uint64_t
angegeben und nur bei einem Systemneustart auf null zurückgesetzt.
Der Zeitstempel des Ereignisses wird auf die Uhrzeit gesetzt, zu der der letzte Schritt für dieses Ereignis ausgeführt wurde.
Informationen zur Bedeutung der Zeit eines Schritts finden Sie unter Schrittzähler.
Im Vergleich zum Schrittzähler kann der Schrittzähler eine höhere Latenz haben (bis zu 10 Sekunden). Dank dieser Latenz ist dieser Sensor sehr genau. Die Schrittzahl nach einem ganzen Tag sollte innerhalb von 10% der tatsächlichen Schrittzahl liegen. Sowohl der Schrittzähler als auch der Schrittzähler erkennen, wenn der Nutzer geht, läuft und Treppen steigt. Sie sollten nicht ausgelöst werden, wenn der Nutzer Fahrrad fährt, Auto fährt oder sich in anderen Fahrzeugen befindet.
Die Hardware muss dafür sorgen, dass die interne Schrittzahl niemals überläuft. Die Mindestgröße des internen Zählers der Hardware muss 16 Bit betragen. Bei einem bevorstehenden Überlauf (höchstens alle ~2^16 Schritte) kann das SoC geweckt werden, damit der Treiber die Zählerwartung durchführen kann.
Wie unter Interaktion erwähnt, darf dieser Sensor bei der Verwendung keine anderen Sensoren beeinträchtigen, insbesondere den Beschleunigungsmesser, der möglicherweise in Gebrauch ist.
Wenn ein bestimmtes Gerät diese Betriebsmodi nicht unterstützt, darf dieser Sensortyp nicht von der HAL gemeldet werden. Das bedeutet, dass es nicht zulässig ist, diesen Sensor in der HAL zu „emulieren“.
Dieser Sensor muss einen geringen Energieverbrauch haben. Wenn die Schritterkennung also nicht in der Hardware erfolgen kann, sollte dieser Sensor nicht definiert werden. Insbesondere, wenn der Schrittzähler aktiviert und der Beschleunigungsmesser deaktiviert ist, sollten nur Schritte Unterbrechungen auslösen (nicht Beschleunigungsmesserdaten).
Neigungssensor
Untergeordneter physischer Sensor: Beschleunigungsmesser (+ ggf. andere, solange sie einen niedrigen Energieverbrauch haben)
Berichtsmodus: Speziell
Niedriger Energieverbrauch
Implementieren Sie nur die Weckversion dieses Sensors.
getDefaultSensor(SENSOR_TYPE_TILT_DETECTOR)
gibt einen Wecksensor zurück
Ein Neigungssensor generiert jedes Mal ein Ereignis, wenn ein Neigungsereignis erkannt wird.
Ein Neigungsereignis wird definiert, wenn sich die Richtung des 2-Sekunden-Mittelwerts der Schwerkraft seit der Aktivierung oder dem letzten vom Sensor generierten Ereignis um mindestens 35 Grad geändert hat. So funktioniert der Algorithmus:
reference_estimated_gravity
= Durchschnitt der Beschleunigungsmessermessungen in der ersten Sekunde nach der Aktivierung oder die geschätzte Schwerkraft, als das letzte Neigungsereignis generiert wurde.current_estimated_gravity
= Durchschnitt der Beschleunigungsmessermessungen der letzten 2 Sekunden.- Wird ausgelöst, wenn
angle(reference_estimated_gravity, current_estimated_gravity) > 35 degrees
Starke Beschleunigungen ohne Änderung der Smartphone-Orientierung sollten kein Neigungsereignis auslösen. Beispielsweise sollte eine scharfe Kurve oder eine starke Beschleunigung beim Autofahren kein Neigungsereignis auslösen, auch wenn der Winkel der durchschnittlichen Beschleunigung um mehr als 35 Grad variieren kann.
Normalerweise wird dieser Sensor nur mithilfe eines Beschleunigungsmessers implementiert. Andere Sensoren können ebenfalls verwendet werden, sofern sie den Stromverbrauch nicht wesentlich erhöhen. Dies ist ein Sensor mit geringem Energieverbrauch, der es dem SoC ermöglichen sollte, in den Ruhemodus zu wechseln. Emulieren Sie diesen Sensor nicht in der HAL. Für jedes Sensorereignis wird 1
in sensors_event_t.data[0]
erfasst.
Neigungssensoren
Drehvektor
Untergeordnete physische Sensoren: Beschleunigungsmesser, Magnetometer und Gyroskop
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_ROTATION_VECTOR)
gibt einen Sensor zurück, der nicht zum Aktivieren dient
Ein Rotationsvektorsensor meldet die Ausrichtung des Geräts relativ zum Koordinatensystem „Ost-Nord-Oben“. Sie wird in der Regel durch die Integration von Beschleunigungsmesser-, Gyroskop- und Magnetometerwerten ermittelt. Das Koordinatensystem „Ost-Nord-Oben“ ist als direkte orthonormale Basis definiert, wobei gilt:
- X zeigt nach Osten und ist tangential zum Boden.
- Y zeigt nach Norden und ist tangential zum Boden.
- Z zeigt zum Himmel und ist senkrecht zum Boden.
Die Ausrichtung des Smartphones wird durch die Drehung dargestellt, die erforderlich ist, um die Koordinaten „Osten-Nord-Oben“ mit den Koordinaten des Smartphones auszurichten. Das bedeutet, dass die Rotation auf den Weltraum (X,Y,Z) angewendet wird, um ihn an die Smartphone-Koordinaten (x,y,z) anzupassen.
Die Drehung kann als Drehung des Smartphones um einen Winkel θ um eine Achse rot_axis
angesehen werden, um von der Referenz-Geräteorientierung (Ost-Nord-Oben) zur aktuellen Geräteorientierung zu gelangen. Die Drehung wird als die vier dimensionslosen Komponenten x, y, z, w eines Einheitsquaternions codiert:
sensors_event_t.data[0] = rot_axis.x*sin(theta/2)
sensors_event_t.data[1] = rot_axis.y*sin(theta/2)
sensors_event_t.data[2] = rot_axis.z*sin(theta/2)
sensors_event_t.data[3] = cos(theta/2)
Dabei gilt:
- Die Felder „x“, „y“ und „z“ von
rot_axis
sind die Ost-Nord-Oben-Koordinaten eines Einheitsvektors, der die Drehachse darstellt. theta
ist der Drehwinkel.
Das Quaternion ist ein Einheitsquaternion: Es muss eine Norm von 1
haben.
Andernfalls kann es zu unerwartetem Clientverhalten kommen.
Außerdem meldet dieser Sensor eine geschätzte Richtungsgenauigkeit:
sensors_event_t.data[4] = estimated_accuracy
(in Bogenmaß)
Der Richtungsfehler darf in 95% der Fälle unter estimated_accuracy
liegen. Dieser Sensor muss ein Gyroskop als Haupteingabe für die Ausrichtungsänderung verwenden.
Dieser Sensor verwendet auch die Eingaben des Beschleunigungsmessers und des Magnetometers, um die Drift des Gyroskops auszugleichen. Er kann nicht nur mit dem Beschleunigungsmesser und dem Magnetometer implementiert werden.
Vektor für die Spieldrehung
Zugrunde liegende physische Sensoren: Beschleunigungsmesser und Gyroskop (kein Magnetometer)
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_GAME_ROTATION_VECTOR)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Rotationsvektorsensor für Spiele ähnelt einem Rotationsvektorsensor, verwendet aber nicht das geomagnetische Feld. Daher zeigt die Y-Achse nicht nach Norden, sondern auf eine andere Referenz. Diese Referenz darf um denselben Betrag driften wie das Gyroskop um die Z‑Achse.
Weitere Informationen zum Festlegen von sensors_event_t.data[0-3]
finden Sie im Hilfeartikel zum Rotationsvektor. Dieser Sensor meldet keine geschätzte Richtungsgenauigkeit: sensors_event_t.data[4]
ist reserviert und sollte auf 0
gesetzt werden.
Im Idealfall sollte ein Smartphone, das gedreht und wieder in die gleiche Position gebracht wird, denselben Vektor für die Drehung im Spiel melden.
Dieser Sensor muss auf einem Gyroskop und einem Beschleunigungsmesser basieren. Das Magnetometer kann nicht als Eingabe verwendet werden, außer indirekt über die Schätzung der Gyroskopabweichung.
Gravity
Zugrunde liegende physische Sensoren: Beschleunigungsmesser und (falls vorhanden) Gyroskop (oder Magnetometer, falls kein Gyroskop vorhanden ist)
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_GRAVITY)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Gravitationssensor meldet die Richtung und Stärke der Schwerkraft in den Koordinaten des Geräts.
Die Komponenten des Gravitationsvektors werden in den Feldern „x“, „y“ und „z“ von sensors_event_t.acceleration
in m/s² angegeben.
Wenn sich das Gerät nicht bewegt, sollte die Ausgabe des Gravitationssensors mit der des Beschleunigungsmessers identisch sein. Auf der Erde beträgt die Erdbeschleunigung etwa 9, 8 m/s².
Wenn das Gerät ein Gyroskop hat, muss der Schwerkraftsensor das Gyroskop und den Beschleunigungsmesser als Eingabe verwenden.
Wenn das Gerät kein Gyroskop hat, muss der Schwerkraftsensor den Beschleunigungsmesser und das Magnetometer als Eingabe verwenden.
Geomagnetischer Drehvektor
Zugrunde liegende physische Sensoren: Beschleunigungsmesser und Magnetometer (kein Gyroskop)
Berichtsmodus: Kontinuierlich
Niedriger Energieverbrauch
getDefaultSensor(SENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein geomagnetischer Drehvektor ähnelt einem Drehvektorsensor, verwendet aber ein Magnetometer und kein Gyroskop.
Dieser Sensor muss auf einem Magnetometer basieren. Er kann nicht mit einem Gyroskop implementiert werden und die Gyroskopeingabe kann von diesem Sensor nicht verwendet werden.
Weitere Informationen zum Festlegen von sensors_event_t.data[0-4]
finden Sie im Hilfeartikel zum Rotationsvektor.
Genau wie beim Drehvektorsensor muss der Richtungsfehler in 95% der Fälle unter der geschätzten Genauigkeit (sensors_event_t.data[4]
) liegen.
Dieser Sensor muss möglichst wenig Strom verbrauchen und daher in der Hardware implementiert werden.
Ausrichtung (eingestellt)
Untergeordnete physische Sensoren: Beschleunigungsmesser, Magnetometer und (falls vorhanden) Gyroskop
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_ORIENTATION)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Hinweis:Dies ist ein älterer Sensortyp, der im Android SDK eingestellt wurde. Er wurde durch den Drehvektorsensor ersetzt, der klarer definiert ist. Verwenden Sie nach Möglichkeit den Drehvektorsensor anstelle des Orientierungssensors.
Ein Ausrichtungssensor meldet die Ausrichtung des Geräts. Die Messungen werden in den Feldern „x“, „y“ und „z“ von sensors_event_t.orientation
in Grad angegeben:
sensors_event_t.orientation.x
: Azimut, der Winkel zwischen der magnetischen Nordrichtung und der Y-Achse, gemessen um die Z-Achse (0<=azimuth<360
). 0=Nord, 90=Osten, 180=Süd, 270=West.sensors_event_t.orientation.y
: Neigung, Drehung um die X-Achse (-180<=pitch<=180
), mit positiven Werten, wenn sich die Z-Achse in Richtung der Y-Achse bewegt.sensors_event_t.orientation.z
: Rollung, Drehung um die Y-Achse (-90<=roll<=90
), mit positiven Werten, wenn sich die X-Achse in Richtung der Z-Achse bewegt.
Hinweis: Aus historischen Gründen ist der Rollwinkel im Uhrzeigersinn positiv. (Mathematisches Vorzeichen: positiv, gegen den Uhrzeigersinn):
Diese Definition unterscheidet sich von den Begriffen „Nicken“, „Gieren“ und „Rollen“, die in der Luftfahrt verwendet werden, wo die X-Achse entlang der Längsseite des Flugzeugs verläuft (von der Leitwerkspitze bis zur Flugzeugnase).
Der Ausrichtungssensor gibt auch über sensors_event_t.orientation.status
an, wie genau seine Messwerte voraussichtlich sind. Weitere Informationen zu den möglichen Werten für dieses Feld finden Sie in den Konstanten
SENSOR_STATUS_*
von
SensorManager
.
Nicht kalibrierte Sensoren
Nicht kalibrierte Sensoren liefern Rohdaten und können eine gewisse Abweichung aufweisen, enthalten aber weniger „Sprünge“ durch Korrekturen, die durch die Kalibrierung angewendet werden. Für einige Apps sind diese nicht kalibrierten Ergebnisse möglicherweise besser geeignet, da sie flüssiger und zuverlässiger sind. Wenn eine App beispielsweise versucht, eine eigene Sensorfusion durchzuführen, können Kalibrierungen die Ergebnisse verfälschen.
Beschleunigungsmesser nicht kalibriert
Untergeordneter physischer Sensor: Beschleunigungsmesser
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_ACCELEROMETER_UNCALIBRATED)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein nicht kalibrierter Beschleunigungsmesser meldet die Beschleunigung des Geräts entlang der drei Sensorachsen ohne Biaskorrektur (Werksbias und Temperaturkompensation werden auf nicht kalibrierte Messungen angewendet) sowie eine Biasschätzung.
Alle Werte sind in SI-Einheiten (m/s²) und werden in den Feldern von sensors_event_t.uncalibrated_accelerometer
angegeben:
x_uncalib
: Beschleunigung (ohne Vorabglättung) entlang der X-Achsey_uncalib
: Beschleunigung (ohne Vorzeichenkorrektur) entlang der Y-Achsez_uncalib
: Beschleunigung (ohne Vorzeichenkorrektur) entlang der Z‑Achsex_bias
: Geschätzte Abweichung entlang der X-Achsey_bias
: Geschätzte Abweichung entlang der Y-Achsez_bias
: Geschätzte Abweichung entlang der Z‑Achse
Gyroskop nicht kalibriert
Verwendeter physischer Sensor: Gyroskop
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_GYROSCOPE_UNCALIBRATED)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein nicht kalibriertes Gyroskop meldet die Drehgeschwindigkeit um die Sensorachsen, ohne eine Bias-Kompensation anzuwenden, zusammen mit einer Bias-Schätzung. Alle Werte sind in Radian/Sekunde angegeben und werden in den Feldern von sensors_event_t.uncalibrated_gyro
erfasst:
x_uncalib
: Winkelgeschwindigkeit (ohne Driftkompensation) um die X-Achsey_uncalib
: Winkelgeschwindigkeit (ohne Driftkompensation) um die Y-Achsez_uncalib
: Winkelgeschwindigkeit (ohne Driftkompensation) um die Z‑Achsex_bias
: Geschätzte Abweichung entlang der X-Achsey_bias
: Geschätzte Abweichung um die Y-Achsez_bias
: Geschätzte Abweichung entlang der Z‑Achse
Die nicht kalibrierte Messung ist konzeptionell die Summe der kalibrierten Messung und der Schätzung der Abweichung: _uncalibrated = _calibrated + _bias
.
Die Werte x_bias
, y_bias
und z_bias
sollten ansteigen, sobald sich die Schätzung der Verzerrung ändert. Ansonsten sollten sie stabil bleiben.
Weitere Informationen zum verwendeten Koordinatensystem finden Sie in der Definition des Gyroskops.
Die Kalibrierung und Temperaturkompensation müssen auf die Messungen angewendet werden. Außerdem muss die Schätzung der Gyroskopabweichung implementiert werden, damit in x_bias
, y_bias
und z_bias
vernünftige Schätzungen erfasst werden können. Wenn die Implementierung die Abweichung nicht schätzen kann, darf dieser Sensor nicht implementiert werden.
Wenn dieser Sensor vorhanden ist, muss auch der entsprechende Gyroskopsensor vorhanden sein und beide Sensoren müssen dieselben sensor_t.name
- und sensor_t.vendor
-Werte haben.
Magnetfeld nicht kalibriert
Untergeordneter physischer Sensor: Magnetometer
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein nicht kalibrierter Magnetfeldsensor meldet das Umgebungsmagnetfeld zusammen mit einer geschätzten Kalibrierung für hartes Eisen. Alle Werte sind in Mikrotesla (µT) und werden in den Feldern von sensors_event_t.uncalibrated_magnetic
angegeben:
x_uncalib
: Magnetfeld (ohne Kompensation für hartes Eisen) entlang der X‑Achsey_uncalib
: Magnetfeld (ohne Kompensation für hartes Eisen) entlang der Y-Achsez_uncalib
: Magnetfeld (ohne Kompensation für hartes Eisen) entlang der Z‑Achsex_bias
: Geschätzte Magnetfeldabweichung entlang der X-Achsey_bias
: Geschätzte Magnetfeldstörung entlang der Y-Achsez_bias
: Geschätzte Magnetfeldabweichung entlang der Z‑Achse
Die nicht kalibrierte Messung ist konzeptionell die Summe der kalibrierten Messung und der Schätzung der Abweichung: _uncalibrated = _calibrated + _bias
.
Der nicht kalibrierte Magnetometer ermöglicht es Algorithmen auf höherer Ebene, die Schätzung von schlechtem hartem Eisen zu verarbeiten. Die Werte x_bias
, y_bias
und z_bias
sollten ansteigen, sobald sich die Schätzung für das Hardware-Equipment ändert. Danach sollten sie stabil bleiben.
Die Messungen müssen mit einer Weicheisenkalibrierung und Temperaturkompensation versehen werden. Außerdem muss die Schätzung der Hardware implementiert werden, damit in x_bias
, y_bias
und z_bias
angemessene Schätzungen erfasst werden können. Wenn die Implementierung die Abweichung nicht schätzen kann, darf dieser Sensor nicht implementiert werden.
Wenn dieser Sensor vorhanden ist, muss auch der entsprechende Magnetfeldsensor vorhanden sein. Außerdem müssen beide Sensoren dieselben sensor_t.name
- und sensor_t.vendor
-Werte haben.
Scharnierwinkel
Berichtsmodus: Bei Änderung
getDefaultSensor(SENSOR_TYPE_HINGE_ANGLE)
gibt einen Wecksensor zurück
Ein Scharnierwinkelsensor misst den Winkel in Grad zwischen zwei wichtigen Teilen des Geräts. Die Bewegung eines Scharniers, die mit diesem Sensortyp gemessen wird, soll die Möglichkeiten ändern, wie Nutzer mit dem Gerät interagieren können, z. B. durch Aufklappen oder Entdecken eines Displays.
Kombinationssensoren für Interaktionen
Einige Sensoren werden hauptsächlich verwendet, um Interaktionen mit dem Nutzer zu erkennen. Wir legen nicht fest, wie diese Sensoren implementiert werden müssen, sie müssen jedoch einen geringen Energieverbrauch haben. Es liegt in der Verantwortung des Geräteherstellers, ihre Qualität im Hinblick auf die Nutzerfreundlichkeit zu überprüfen.
Aufwachgeste
Untergeordnete physische Sensoren: Undefiniert (alles mit geringem Energieverbrauch)
Berichtsmodus: One-Shot
Niedriger Energieverbrauch
Implementieren Sie nur die Weckversion dieses Sensors.
getDefaultSensor(SENSOR_TYPE_WAKE_GESTURE)
gibt einen Wecksensor zurück
Mit einem Sensor für Aktivierungsgesten kann das Gerät durch eine bestimmte Bewegung aktiviert werden. Wenn dieser Sensor ausgelöst wird, verhält sich das Gerät so, als wäre die Ein/Aus-Taste gedrückt worden, und das Display wird eingeschaltet. Dieses Verhalten (Einschalten des Displays, wenn dieser Sensor ausgelöst wird) kann vom Nutzer in den Geräteeinstellungen deaktiviert werden. Änderungen an den Einstellungen wirken sich nicht auf das Verhalten des Sensors aus, sondern nur darauf, ob das Framework das Display einschaltet, wenn der Sensor ausgelöst wird. Die zu erkennende Geste ist nicht festgelegt und kann vom Gerätehersteller ausgewählt werden.
Dieser Sensor muss einen geringen Energieverbrauch haben, da er wahrscheinlich rund um die Uhr aktiviert ist.
Für jedes Sensorereignis wird 1
in sensors_event_t.data[0]
erfasst.
Touch-Geste zum Aufnehmen
Untergeordnete physische Sensoren: Undefiniert (alles mit geringem Energieverbrauch)
Berichtsmodus: One-Shot
Niedriger Energieverbrauch
Implementieren Sie nur die Weckversion dieses Sensors.
getDefaultSensor(SENSOR_TYPE_PICK_UP_GESTURE)
gibt einen Wecksensor zurück
Ein Sensor für die Aufheb-Geste wird ausgelöst, wenn das Gerät aufgehoben wird, unabhängig davon, wo es sich zuvor befand (Tisch, Tasche, Hosentasche).
Für jedes Sensorereignis wird 1
in sensors_event_t.data[0]
erfasst.
Geste für die Schnellinfo
Untergeordnete physische Sensoren: Undefiniert (alles mit geringem Energieverbrauch)
Berichtsmodus: One-Shot
Niedriger Energieverbrauch
Implementieren Sie nur die Weckversion dieses Sensors.
getDefaultSensor(SENSOR_TYPE_GLANCE_GESTURE)
gibt einen Wecksensor zurück
Mit einem Sensor für Gesten zum Blicken kann der Bildschirm kurz eingeschaltet werden, damit der Nutzer aufgrund einer bestimmten Bewegung Inhalte auf dem Bildschirm sehen kann. Wenn dieser Sensor ausgelöst wird, schaltet das Gerät den Bildschirm kurz ein, damit der Nutzer Benachrichtigungen oder andere Inhalte sehen kann, während das Gerät gesperrt und nicht interaktiv ist (Ruhemodus). Anschließend wird der Bildschirm wieder ausgeschaltet. Dieses Verhalten (kurzes Einschalten des Displays, wenn dieser Sensor ausgelöst wird) kann vom Nutzer in den Geräteeinstellungen deaktiviert werden. Änderungen an den Einstellungen wirken sich nicht auf das Verhalten des Sensors aus, sondern nur darauf, ob das Framework den Bildschirm kurz einschaltet, wenn er ausgelöst wird. Die zu erkennende Geste ist nicht festgelegt und kann vom Gerätehersteller ausgewählt werden.
Dieser Sensor muss einen geringen Energieverbrauch haben, da er wahrscheinlich rund um die Uhr aktiviert ist.
Für jedes Sensorereignis wird 1
in sensors_event_t.data[0]
erfasst.
IMU-Sensoren mit begrenzter Anzahl von Achsen
IMU-Sensoren mit begrenzten Achsen sind ab Android 13 verfügbar. Sie unterstützen Anwendungsfälle, in denen nicht alle drei Achsen (x, y, z) verfügbar sind. Bei Standard-IMU-Typen unter Android (z. B.
SENSOR_TYPE_ACCELEROMETER
und
SENSOR_TYPE_GYROSCOPE
) wird davon ausgegangen, dass alle drei Achsen unterstützt werden. Allerdings unterstützen nicht alle Formfaktoren und Geräte 3‑Achsen-Beschleunigungsmesser und 3‑Achsen-Gyroskope.
Begrenzte Achsen des Beschleunigungsmessers
Zugrunde liegende physische Sensoren: Beschleunigungsmesser
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_ACCELEROMETER_LIMITED_AXES)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Beschleunigungsmesser mit eingeschränkten Achsen entspricht TYPE_ACCELEROMETER
, unterstützt aber Fälle, in denen eine oder zwei Achsen nicht unterstützt werden.
Die letzten drei vom Sensor gemeldeten Sensorereigniswerte geben an, ob der Beschleunigungswert für die X-, Y- und Z-Achsen unterstützt wird. Der Wert 1.0
gibt an, dass die Achse unterstützt wird. Der Wert 0
bedeutet, dass sie nicht unterstützt wird. Gerätehersteller geben die unterstützten Achsen zum Zeitpunkt der Build-Erstellung an. Die Werte ändern sich nicht während der Laufzeit.
Gerätehersteller müssen die Beschleunigungswerte für nicht verwendete Achsen auf 0
festlegen, anstatt undefinierte Werte zu verwenden.
Gyroskop mit eingeschränkten Achsen
Zugrunde liegende physische Sensoren: Gyroskop
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_GYROSCOPE_LIMITED_AXES)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein Gyroskop mit eingeschränkten Achsen entspricht TYPE_GYROSCOPE
, unterstützt aber Fälle, in denen eine oder zwei Achsen nicht unterstützt werden.
Die letzten drei vom Sensor gemeldeten Sensorereigniswerte geben an, ob der Wert für die Winkelgeschwindigkeit für die X-, Y- und Z-Achsen unterstützt wird. Der Wert 1.0
gibt an, dass die Achse unterstützt wird. Der Wert 0
bedeutet, dass sie nicht unterstützt wird. Gerätehersteller geben die unterstützten Achsen zum Zeitpunkt der Build-Erstellung an. Die Werte ändern sich nicht während der Laufzeit.
Gerätehersteller müssen die Werte für die Winkelgeschwindigkeit für nicht verwendete Achsen auf 0
festlegen.
Begrenzte Achsen des Beschleunigungsmessers nicht kalibriert
Zugrunde liegende physische Sensoren: Beschleunigungsmesser
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_ACCELEROMETER_LIMITED_AXES_UNCALIBRATED)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein nicht kalibrierter Beschleunigungsmesser mit eingeschränkten Achsen entspricht TYPE_ACCELEROMETER_UNCALIBRATED
, unterstützt aber Fälle, in denen eine oder zwei Achsen nicht unterstützt werden.
Die letzten drei vom Sensor gemeldeten Sensorereigniswerte geben an, ob die Beschleunigungs- und Vorzeichenvorgaben für die X-, Y- und Z-Achsen unterstützt werden. Der Wert 1.0
gibt an, dass die Achse unterstützt wird, und der Wert 0
, dass sie nicht unterstützt wird. Gerätehersteller geben die unterstützten Achsen zum Zeitpunkt der Build-Erstellung an. Die Werte ändern sich nicht während der Laufzeit.
Gerätehersteller müssen die Beschleunigungs- und Vorzeichenwerte für nicht verwendete Achsen auf 0
festlegen.
Gyroskop – eingeschränkte Achsen nicht kalibriert
Zugrunde liegende physische Sensoren: Gyroskop
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_GYROSCOPE_LIMITED_AXES_UNCALIBRATED)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ein nicht kalibrierter Sensor mit eingeschränkten Achsen eines Gyroskops entspricht TYPE_GYROSCOPE_UNCALIBRATED
, unterstützt aber Fälle, in denen eine oder zwei Achsen nicht unterstützt werden.
Die letzten drei vom Sensor gemeldeten Sensorereigniswerte geben an, ob die Werte für Winkelgeschwindigkeit und Drift für die X-, Y- und Z-Achsen unterstützt werden. Der Wert 1.0
gibt an, dass die Achse unterstützt wird, und der Wert 0
, dass sie nicht unterstützt wird. Gerätehersteller geben die unterstützten Achsen zum Zeitpunkt der Build-Erstellung an. Die Werte ändern sich nicht während der Laufzeit.
Gerätehersteller müssen die Werte für Winkelgeschwindigkeit und Drift für nicht verwendete Achsen auf 0
festlegen.
IMU mit begrenzten Achsen
Untergeordnete physische Sensoren: beliebige Kombination aus 3-Achsen-Beschleunigungsmesser, 3-Achsen-Gyroskop, nicht kalibriertem 3-Achsen-Beschleunigungsmesser und nicht kalibriertem 3-Achsen-Gyroskop
Berichtsmodus: Kontinuierlich
Ein zusammengesetzter IMU-Sensor mit begrenzten Achsen entspricht einem IMU-Sensor mit begrenzten Achsen. Anstatt jedoch von der HAL unterstützt zu werden, wandelt er die 3‑Achsen-Sensordaten in die entsprechenden Varianten mit begrenzten Achsen um. Diese Kompositsensoren sind nur für Geräte aus der Automobilbranche aktiviert.
Die folgende Tabelle zeigt ein Beispiel für die Umwandlung von einem standardmäßigen 3‑Achsen-Beschleunigungsmesser in einen zusammengesetzten Beschleunigungsmesser mit eingeschränkten Achsen.
SensorEvent-Werte für SENSOR_TYPE_ACCELEROMETER | Beispiel für ein Sensor-Ereignis vom Typ SENSOR_TYPE_ACCELEROMETER | Zusammengesetztes Sensor-Ereignis vom Typ SENSOR_TYPE_ACCELEROMETER_LIMITED_AXES |
---|---|---|
values[0] | -0,065 |
-0,065 |
values[1] | 0,078 |
0,078 |
values[2] | 9.808 |
9.808 |
values[3] | – |
1.0 |
values[4] | – |
1.0 |
values[5] | – |
1.0 |
Automobilsensoren
Sensoren zur Unterstützung von Anwendungsfällen im Automobilbereich.
Überschrift
Zugrunde liegende physische Sensoren: beliebige Kombination aus GPS, Magnetometer, Beschleunigungsmesser und Gyroskop
Berichtsmodus: Kontinuierlich
getDefaultSensor(SENSOR_TYPE_HEADING)
gibt einen Sensor zurück, der nicht zum Aufwecken dient
Ab Android 13 misst ein Richtungssensor die Richtung, in die das Gerät zeigt, bezogen auf den geografischen Norden, in Grad. Der Richtungssensor enthält zwei SensorEvent
-Werte.
Eine für die gemessene Gerätepeilung und eine für die Richtigkeit des angegebenen Peilungswerts.
Die von diesem Sensor gemeldeten Werte für den Kurs müssen zwischen 0.0
(einschließlich) und 360.0
(ausschließlich) liegen. Dabei steht 0
für Norden, 90
für Osten, 180
für Süden und 270
für Westen.
Die Genauigkeit dieses Sensors wird mit einer Wahrscheinlichkeit von 68 % angegeben. Wenn die zugrunde liegende Verteilung normalverteilt ist, entspricht die Genauigkeit einer Standardabweichung. Wenn der Richtungssensor beispielsweise einen Wert von 60 Grad und eine Genauigkeit von 10 Grad zurückgibt, liegt die Wahrscheinlichkeit, dass der tatsächliche Wert zwischen 50 Grad und 70 Grad liegt, bei 68 %.