Diese Anleitung ist mit Health Connect-Version 1.1.0-alpha12 kompatibel.
In diesem Leitfaden wird beschrieben, wie Daten in Health Connect geschrieben oder aktualisiert werden.
Nullwerte verarbeiten
Einige Datentypen wie Schritte, Strecke oder Kalorien haben möglicherweise den Wert 0.
Schreibe nur Nullwerte, wenn sie die tatsächliche Inaktivität widerspiegeln, während der Nutzer das Gerät getragen hat. Schreibe keine Nullwerte, wenn das Gerät nicht getragen wurde, Daten fehlen oder der Akku leer ist. Lassen Sie den Datensatz in solchen Fällen weg, um irreführende Daten zu vermeiden.
Datenstruktur einrichten
Bevor wir Daten schreiben, müssen wir die Datensätze einrichten. Für mehr als 50 Datentypen gibt es jeweils eigene Strukturen. Weitere Informationen zu den verfügbaren Datentypen finden Sie in der Jetpack-Referenz.
Grundlegende Datensätze
Der Datentyp Schritte in Health Connect erfasst die Anzahl der Schritte, die ein Nutzer zwischen den Messungen zurückgelegt hat. Schrittzahlen sind ein gängiger Messwert auf Gesundheits-, Fitness- und Wellnessplattformen.
Im folgenden Beispiel wird gezeigt, wie Schrittzählerdaten festgelegt werden:
val zoneOffset = ZoneOffset.systemDefault().rules.getOffset(startTime) val stepsRecord = StepsRecord( count = 120, startTime = startTime, endTime = endTime, startZoneOffset = zoneOffset, endZoneOffset = zoneOffset, metadata = Metadata( device = Device(type = Device.TYPE_WATCH), recordingMethod = Metadata.RECORDING_METHOD_AUTOMATICALLY_RECORDED ) ) healthConnectClient.insertRecords(listOf(stepsRecord))
Aufzeichnungen mit Maßeinheiten
In Health Connect können Werte zusammen mit ihren Maßeinheiten gespeichert werden, um die Genauigkeit zu gewährleisten. Ein Beispiel ist der Datentyp Ernährung, der sehr umfangreich ist. Sie umfasst eine Vielzahl optionaler Nährwertfelder, die von Gesamtkohlenhydraten bis hin zu Vitaminen reichen. Jeder Datenpunkt steht für die Nährstoffe, die möglicherweise im Rahmen einer Mahlzeit oder eines Lebensmittels aufgenommen wurden.
Bei diesem Datentyp werden alle Nährstoffe in Einheiten von Masse angegeben, während energy in einer Einheit von Energie angegeben wird.
Das folgende Beispiel zeigt, wie Ernährungsdaten für einen Nutzer festgelegt werden, der eine Banane gegessen hat:
val endTime = Instant.now() val startTime = endTime.minus(Duration.ofMinutes(1)) val banana = NutritionRecord( name = "banana", energy = 105.0.kilocalories, dietaryFiber = 3.1.grams, potassium = 0.422.grams, totalCarbohydrate = 27.0.grams, totalFat = 0.4.grams, saturatedFat = 0.1.grams, sodium = 0.001.grams, sugar = 14.0.grams, vitaminB6 = 0.0005.grams, vitaminC = 0.0103.grams, startTime = startTime, endTime = endTime, startZoneOffset = ZoneOffset.UTC, endZoneOffset = ZoneOffset.UTC, metadata = Metadata( device = Device(type = Device.TYPE_PHONE) ) )
Datensätze mit Seriendaten
In Health Connect kann eine Liste von Zeitreihendaten gespeichert werden. Ein Beispiel ist der Datentyp Heart Rate (Herzfrequenz), der eine Reihe von Herzschlagsamples erfasst, die zwischen den Messungen erkannt wurden.
In diesem Datentyp wird der Parameter samples durch eine Liste von Herzfrequenzmessungen dargestellt. Jede Stichprobe enthält einen beatsPerMinute-Wert und einen time-Wert.
Im folgenden Beispiel wird gezeigt, wie du Daten für die Herzfrequenzreihe festlegst:
val endTime = Instant.now() val startTime = endTime.minus(Duration.ofMinutes(5)) val heartRateRecord = HeartRateRecord( startTime = startTime, startZoneOffset = ZoneOffset.UTC, endTime = endTime, endZoneOffset = ZoneOffset.UTC, // records 10 arbitrary data, to replace with actual data samples = List(10) { index -> HeartRateRecord.Sample( time = startTime + Duration.ofSeconds(index.toLong()), beatsPerMinute = 100 + index.toLong(), ) }, metadata = Metadata( device = Device(type = Device.TYPE_WATCH) ))
Berechtigungen vom Nutzer anfordern
Nachdem Sie eine Client-Instanz erstellt haben, muss Ihre App Berechtigungen vom Nutzer anfordern. Nutzer müssen jederzeit die Möglichkeit haben, Berechtigungen zu erteilen oder zu verweigern. Erstellen Sie dazu eine Reihe von Berechtigungen für die erforderlichen Datentypen. Die Berechtigungen im Set müssen zuerst in Ihrem Android-Manifest deklariert werden.
val permissions = setOf( HealthPermission.getReadPermission(HeartRateRecord::class), HealthPermission.getWritePermission(HeartRateRecord::class), HealthPermission.getReadPermission(StepsRecord::class), HealthPermission.getWritePermission(StepsRecord::class) )
getGrantedPermissions, um zu prüfen, ob Ihrer App bereits die erforderlichen Berechtigungen erteilt wurden. Falls nicht, verwenden Sie createRequestPermissionResultContract, um diese Berechtigungen anzufordern. Dadurch wird der Health Connect-Berechtigungsbildschirm angezeigt.
val permissions = setOf( HealthPermission.getReadPermission(StepsRecord::class), HealthPermission.getWritePermission(StepsRecord::class), HealthPermission.getReadPermission(HeartRateRecord::class), HealthPermission.getWritePermission(HeartRateRecord::class) ) val requestPermissionsLauncher = rememberLauncherForActivityResult( contract = PermissionController.createRequestPermissionResultContract() ) { grantedPermissions -> if (grantedPermissions.containsAll(permissions)) { coroutineScope.launch { snackbarHostState.showSnackbar("Permissions granted!") } } else { coroutineScope.launch { snackbarHostState.showSnackbar("Permissions denied.") } } }
Daten schreiben
Einer der häufigsten Workflows in Health Connect ist das Schreiben von Daten. Verwenden Sie insertRecords, um Einträge hinzuzufügen.
Das folgende Beispiel zeigt, wie Daten zum Einfügen von Schrittzahlen geschrieben werden:
val zoneOffset = ZoneOffset.systemDefault().rules.getOffset(startTime) val stepsRecord = StepsRecord( count = 120, startTime = startTime, endTime = endTime, startZoneOffset = zoneOffset, endZoneOffset = zoneOffset, metadata = Metadata( device = Device(type = Device.TYPE_WATCH), recordingMethod = Metadata.RECORDING_METHOD_AUTOMATICALLY_RECORDED ) ) healthConnectClient.insertRecords(listOf(stepsRecord))
Daten aktualisieren
Wenn Sie einen oder mehrere Datensätze ändern müssen, insbesondere wenn Sie Ihren App-Datenspeicher mit Daten aus Health Connect synchronisieren müssen, können Sie Ihre Daten aktualisieren. Es gibt zwei Möglichkeiten, vorhandene Daten zu aktualisieren. Welche Sie verwenden, hängt von der Kennung ab, mit der Datensätze gesucht werden.
Metadaten
Es lohnt sich, zuerst die Klasse Metadata zu untersuchen, da sie für die Aktualisierung von Daten erforderlich ist. Beim Erstellen hat jedes Record in Health Connect ein Feld metadata. Die folgenden Eigenschaften sind für die Synchronisierung relevant:
| Properties | Beschreibung |
|---|---|
id
|
Jeder Record in Health Connect hat einen eindeutigen id-Wert.Health Connect füllt diesen Wert automatisch aus beim Einfügen eines neuen Datensatzes. |
lastModifiedTime
|
Für jedes Record wird auch der Zeitpunkt der letzten Änderung des Datensatzes erfasst.Health Connect füllt diese Informationen automatisch aus. |
clientRecordId
|
Jeder Record kann eine eindeutige ID haben, die als Referenz in Ihrem App-Datenspeicher dient.
Dieser Wert wird von Ihrer App bereitgestellt. |
clientRecordVersion
|
Wenn ein Datensatz clientRecordId hat, kann clientRecordVersion verwendet werden, um die Daten mit der Version in Ihrem App-Datenspeicher zu synchronisieren.Ihre App stellt diesen Wert bereit. |
Nach dem Lesen nach Zeitbereich aktualisieren
Wenn Sie Daten aktualisieren möchten, bereiten Sie zuerst die erforderlichen Datensätze vor. Nehmen Sie bei Bedarf Änderungen an den Datensätzen vor. Rufen Sie dann updateRecords auf, um die Änderungen vorzunehmen.
Im folgenden Beispiel wird gezeigt, wie Daten aktualisiert werden. Dazu werden die Zeitzonen-Offsetwerte jedes Datensatzes in PST angepasst.
suspend fun updateSteps( healthConnectClient: HealthConnectClient, prevRecordStartTime: Instant, prevRecordEndTime: Instant ) { try { val request = healthConnectClient.readRecords( ReadRecordsRequest( recordType = StepsRecord::class, timeRangeFilter = TimeRangeFilter.between( prevRecordStartTime, prevRecordEndTime ) ) ) val newStepsRecords = arrayListOf<StepsRecord>() for (record in request.records) { // Adjusted both offset values to reflect changes val sr = StepsRecord( count = record.count, startTime = record.startTime, startZoneOffset = record.startTime.atZone(ZoneId.of("PST")).offset, endTime = record.endTime, endZoneOffset = record.endTime.atZone(ZoneId.of("PST")).offset, metadata = record.metadata ) newStepsRecords.add(sr) } healthConnectClient.updateRecords(newStepsRecords) } catch (e: Exception) { // Run error handling here } }
Upsert über Client-Datensatz-ID
Wenn Sie die optionalen Werte „Client Record ID“ (Clientdatensatz-ID) und „Client Record Version“ (Clientdatensatz-Version) verwenden, empfehlen wir, insertRecords anstelle von updateRecords zu verwenden.
Mit der Funktion insertRecords können Daten eingefügt oder aktualisiert werden.
Wenn die Daten in Health Connect anhand der angegebenen Client-Datensatz-IDs vorhanden sind, werden sie überschrieben. Andernfalls werden sie als neue Daten geschrieben.
Dieses Szenario ist nützlich, wenn Sie Daten aus dem Datenspeicher Ihrer App mit Health Connect synchronisieren müssen.
Das folgende Beispiel zeigt, wie Sie einen Upsert für Daten ausführen, die aus dem App-Datenspeicher abgerufen wurden:
fun pullStepsFromDatastore(startTime: Instant, endTime: Instant) : ArrayList<StepsRecord> { val appStepsRecords = arrayListOf<StepsRecord>() // Pull data from app datastore // ... // Make changes to data if necessary // ... // Store data in appStepsRecords // ... var sr = StepsRecord( metadata = Metadata( clientRecordId = "Your client record ID", device = Device(type = Device.TYPE_WATCH) ), startTime = startTime, startZoneOffset = startTime.atZone(ZoneId.of("PST")).offset, endTime = endTime, endZoneOffset = endTime.atZone(ZoneId.of("PST")).offset, count = 120 ) appStepsRecords.add(sr) // ... return appStepsRecords } suspend fun upsertSteps( healthConnectClient: HealthConnectClient, newStepsRecords: ArrayList<StepsRecord> ) { try { healthConnectClient.insertRecords(newStepsRecords) } catch (e: Exception) { // Run error handling here } }
Danach können Sie diese Funktionen in Ihrem Hauptthread aufrufen.
upsertSteps(healthConnectClient, pullStepsFromDatastore( startTime = startTime, endTime = endTime ))
Wertprüfung in der Clientdatensatzversion
Wenn Ihr Prozess zum Einfügen und Aktualisieren von Daten die Client Record Version umfasst, führt Health Connect Vergleichsprüfungen für die clientRecordVersion-Werte durch. Wenn die Version aus den eingefügten Daten höher ist als die Version aus den vorhandenen Daten, wird der Upsert-Vorgang ausgeführt. Andernfalls wird die Änderung ignoriert und der Wert bleibt gleich.
Wenn Sie die Versionsverwaltung in Ihre Daten aufnehmen möchten, müssen Sie Metadata.clientRecordVersion einen Long-Wert basierend auf Ihrer Versionsverwaltungslogik bereitstellen.
val endTime = Instant.now() val startTime = endTime.minus(Duration.ofMinutes(15)) val stepsRecord = StepsRecord( count = 100L, startTime = startTime, startZoneOffset = ZoneOffset.UTC, endTime = endTime, endZoneOffset = ZoneOffset.UTC, metadata = Metadata( clientRecordId = "Your supplied record ID", clientRecordVersion = 0L, // Your supplied record version device = Device(type = Device.TYPE_WATCH) ) )
Bei Upserts wird version nicht automatisch inkrementiert, wenn Änderungen vorgenommen werden. So wird verhindert, dass Daten unerwartet überschrieben werden. Sie müssen also manuell einen höheren Wert angeben.
Allgemeine Anleitung
Ihre App sollte alle unterstützten selbst erhobenen Daten schreiben. Optional können Sie festlegen, dass Ihre App Daten aus Drittanbieterquellen schreibt. Wenn Ihre App jedoch Daten aus Health Connect gelesen hat, sollten diese Daten nicht wieder in Health Connect geschrieben werden.
Wenn Sie Daten schreiben, die aus einer anderen Quelle importiert oder abgeleitet wurden, müssen Sie die Herkunft und die Metadaten des Quellgeräts korrekt angeben. Dazu müssen Sie für jeden geschriebenen Datensatz die folgenden Metadaten angeben:
recordingMethod: Bei automatisch oder manuell aufgezeichneten Daten muss die Aufzeichnungsmethode aktualisiert werden, um die Art der aufgezeichneten Aktivität widerzuspiegeln:RECORDING_METHOD_AUTOMATICALLY_RECORDED: Wenn die Daten automatisch aufgezeichnet wurden, z. B. wenn ein Fitness-Tracker automatisch erkannt hat, dass der Nutzer joggen war.RECORDING_METHOD_ACTIVELY_RECORDED: Gibt an, ob der Nutzer eine neue Aktivität gestartet hat, z. B. Radfahren auf seinem Wearable.RECORDING_METHOD_MANUAL_ENTRY: Gibt an, ob der Nutzer die Daten manuell eingegeben hat.
device.type: Sie müssen einen Gerätetyp aus einem der unterstütztenDevice-Typen angeben.device.manufacturer: Der Hersteller des Geräts, z. B. „Fitbit“.device.model: Das Modell des Geräts, z. B. „Charge 3“.
Das korrekte Festlegen von Metadaten ist entscheidend für die Datentransparenz und hilft Nutzern, nachzuvollziehen, woher ihre Gesundheitsinformationen stammen. Vollständige Informationen finden Sie im Leitfaden zu Health Connect-Metadaten.
Wenn Daten in Ihre App aus einer anderen App importiert wurden, ist die andere App dafür verantwortlich, ihre eigenen Daten in Health Connect zu schreiben.
Es ist auch ratsam, Logik zu implementieren, die Schreibausnahmen wie Daten außerhalb des zulässigen Bereichs oder einen internen Systemfehler behandelt. Sie können Ihre Backoff- und Wiederholungsstrategien auf einen Mechanismus zur Jobplanung anwenden. Wenn das Schreiben in Health Connect letztendlich nicht erfolgreich ist, muss Ihre App den Exportvorgang fortsetzen können. Vergessen Sie nicht, Fehler zu protokollieren und zu melden, um die Diagnose zu erleichtern.
Beim Erfassen von Daten gibt es je nach Art der Datenerfassung in Ihrer App einige Empfehlungen, die Sie beachten können.
Umgang mit Zeitzonen
Vermeiden Sie es, beim Schreiben zeitbasierter Datensätze standardmäßig Offsets auf zoneOffset.UTC festzulegen, da dies zu ungenauen Zeitstempeln führen kann, wenn sich Nutzer in anderen Zeitzonen befinden. Berechnen Sie den Offset stattdessen anhand des tatsächlichen Standorts des Geräts. Sie können die Zeitzone des Geräts mit ZoneId.systemDefault() abrufen.
val endTime = Instant.now() val startTime = endTime.minus(Duration.ofDays(1)) val stepsRecords = mutableListOf<StepsRecord>() var sampleTime = startTime val minutesBetweenSamples = 15L while (sampleTime < endTime) { // Get the default ZoneId then convert it to an offset val zoneOffset = ZoneOffset.systemDefault().rules.getOffset(sampleTime) stepsRecords += StepsRecord( startTime = sampleTime.minus(Duration.ofMinutes(minutesBetweenSamples)), startZoneOffset = zoneOffset, endTime = sampleTime, endZoneOffset = zoneOffset, count = Random.nextLong(1, 100), metadata = Metadata(), ) sampleTime = sampleTime.plus(Duration.ofMinutes(minutesBetweenSamples)) } healthConnectClient.insertRecords( stepsRecords )
Weitere Informationen finden Sie in der Dokumentation zu ZoneId.
Schreibhäufigkeit und ‑detaillierungsgrad
Verwenden Sie beim Schreiben von Daten in Health Connect eine angemessene Auflösung. Wenn Sie die richtige Auflösung verwenden, können Sie die Speicherlast reduzieren und gleichzeitig konsistente und genaue Daten beibehalten. Die Datenauflösung umfasst zwei Aspekte:
- Häufigkeit des Schreibvorgangs: Wie oft Ihre Anwendung neue Daten in Health Connect schreibt.
- Schreiben Sie Daten so oft wie möglich, wenn neue Daten verfügbar sind, und achten Sie dabei auf die Geräteleistung.
- Um die Akkulaufzeit und andere Leistungsaspekte nicht negativ zu beeinträchtigen, sollte das maximale Intervall zwischen Schreibvorgängen 15 Minuten betragen.
- Granularität der geschriebenen Daten: Wie oft die Daten erhoben wurden.
- Schreibe beispielsweise alle 5 Sekunden Herzfrequenz-Messwerte.
- Nicht für jeden Datentyp ist dieselbe Stichprobenrate erforderlich. Es bringt wenig, Schrittzählerdaten jede Sekunde zu aktualisieren, im Gegensatz zu einer weniger häufigen Aktualisierung, z. B. alle 60 Sekunden.
- Höhere Samplingraten können Nutzern einen detaillierteren Einblick in ihre Gesundheits- und Fitnessdaten geben. Die Häufigkeit der Abtastrate sollte ein ausgewogenes Verhältnis zwischen Detail und Leistung aufweisen.
Zusätzliche Richtlinien
Beachten Sie beim Schreiben von Daten die folgenden Richtlinien:
- Bei jeder Synchronisierung werden nur neue Daten und aktualisierte Daten geschrieben, die seit der letzten Synchronisierung geändert wurden.
- Chunk-Anfragen mit maximal 1.000 Datensätzen pro Schreibanfrage.
- Aufgaben dürfen nur ausgeführt werden, wenn das Gerät inaktiv ist und der Akkustand nicht niedrig ist.
- Verwenden Sie für Hintergrundaufgaben WorkManager, um regelmäßige Aufgaben mit einem maximalen Zeitraum von 15 Minuten zu planen.
Im folgenden Code wird WorkManager verwendet, um regelmäßige Hintergrundaufgaben mit einem maximalen Zeitraum von 15 Minuten und einem flexiblen Intervall von 5 Minuten zu planen. Diese Konfiguration wird mit der Klasse PeriodicWorkRequest.Builder festgelegt.
val constraints = Constraints.Builder()
.requiresBatteryNotLow()
.requiresDeviceIdle(true)
.build()
val writeDataWork = PeriodicWorkRequestBuilder<WriteDataToHealthConnectWorker>(
15,
TimeUnit.MINUTES,
5,
TimeUnit.MINUTES
)
.setConstraints(constraints)
.build()
Aktive Verfolgung
Dazu gehören Apps, die ereignisbasiertes Tracking durchführen, z. B. für Training und Schlaf, oder manuelle Nutzereingaben wie Ernährung. Diese Datensätze werden erstellt, wenn sich die App im Vordergrund befindet oder in seltenen Fällen, wenn sie mehrmals am Tag verwendet wird.
Prüfe, ob deine App Health Connect nicht für die gesamte Dauer des Ereignisses im Hintergrund ausführt.
Daten müssen auf eine der folgenden Arten in Health Connect geschrieben werden:
- Synchronisiere Daten mit Health Connect, nachdem das Ereignis abgeschlossen ist. Synchronisieren Sie beispielsweise Daten, wenn der Nutzer eine aufgezeichnete Trainingseinheit beendet.
- Planen Sie mit
WorkManagereine einmalige Aufgabe, um Daten später zu synchronisieren.
Best Practices für Granularität und Häufigkeit von Schreibvorgängen
Verwenden Sie beim Schreiben von Daten in Health Connect eine angemessene Auflösung. Wenn Sie die richtige Auflösung verwenden, können Sie die Speicherlast reduzieren und gleichzeitig konsistente und genaue Daten beibehalten. Die Datenauflösung umfasst zwei Aspekte:
Häufigkeit der Schreibvorgänge: Wie oft Ihre Anwendung neue Daten in Health Connect überträgt. Schreiben Sie Daten so oft wie möglich, wenn neue Daten verfügbar sind, und achten Sie dabei auf die Geräteleistung. Um die Akkulaufzeit und andere Leistungsaspekte nicht negativ zu beeinträchtigen, sollte das maximale Intervall zwischen Schreibvorgängen 15 Minuten betragen.
Granularität der geschriebenen Daten: Wie oft wurden die Daten, die übertragen wurden, erhoben? Schreibe beispielsweise alle 5 Sekunden Herzfrequenz-Messwerte. Nicht für jeden Datentyp ist dieselbe Stichprobenrate erforderlich. Es bringt wenig, Schrittzahldaten jede Sekunde zu aktualisieren, anstatt in einem weniger häufigen Rhythmus, z. B. alle 60 Sekunden. Höhere Stichprobenraten können Nutzern jedoch einen detaillierteren und genaueren Einblick in ihre Gesundheits- und Fitnessdaten geben. Die Häufigkeit der Abtastrate sollte ein ausgewogenes Verhältnis zwischen Detail und Leistung bieten.
Datensätze für Seriendaten strukturieren
Bei Datentypen, die eine Reihe von Stichproben verwenden, z. B. HeartRateRecord, ist es wichtig, dass Sie Ihre Datensätze richtig strukturieren. Anstatt einen einzelnen, tageslangen Datensatz zu erstellen, der ständig aktualisiert wird, sollten Sie mehrere kleinere Datensätze erstellen, die jeweils ein bestimmtes Zeitintervall darstellen.
Für Herzfrequenzdaten sollten Sie beispielsweise für jede Minute ein neues HeartRateRecord erstellen. Jeder Datensatz hätte eine Start- und Endzeit für diese Minute und würde alle in dieser Minute erfassten Herzfrequenzmessungen enthalten.
Bei regelmäßigen Synchronisierungen mit Health Connect (z. B. alle 15 Minuten) sollte Ihre App alle Ein-Minuten-Datensätze schreiben, die seit der letzten Synchronisierung erstellt wurden. So bleiben Datensätze in einer überschaubaren Größe und die Leistung bei der Abfrage und Verarbeitung von Daten wird verbessert.
Im folgenden Beispiel wird gezeigt, wie ein HeartRateRecord für eine einzelne Minute mit mehreren Stichproben erstellt wird:
val startTime = Instant.now().truncatedTo(ChronoUnit.MINUTES) val endTime = startTime.plus(Duration.ofMinutes(1)) val heartRateRecord = HeartRateRecord( startTime = startTime, startZoneOffset = ZoneOffset.UTC, endTime = endTime, endZoneOffset = ZoneOffset.UTC, // Create a new record every minute, containing a list of samples. samples = listOf( HeartRateRecord.Sample( time = startTime + Duration.ofSeconds(15), beatsPerMinute = 80, ), HeartRateRecord.Sample( time = startTime + Duration.ofSeconds(30), beatsPerMinute = 82, ), HeartRateRecord.Sample( time = startTime + Duration.ofSeconds(45), beatsPerMinute = 85, ) ), metadata = Metadata( device = Device(type = Device.TYPE_WATCH) ))
Den ganzen Tag über überwachte Daten schreiben
Bei Daten, die fortlaufend erfasst werden, z. B. Schritte, sollte Ihre App so oft wie möglich in Health Connect schreiben, wenn neue Daten verfügbar sind. Um die Akkulaufzeit und andere Leistungsaspekte nicht negativ zu beeinträchtigen, sollte das maximale Intervall zwischen Schreibvorgängen 15 Minuten betragen.
Datentyp |
Einheit |
Erwartet |
Beispiel |
Schritte |
Schritte |
Jede Minute |
23:14 – 23:15 – 5 Schritte 23:16 – 23:17 – 22 Schritte 23:17 – 23:18 – 8 Schritte |
StepsCadence |
Schritte/min |
Jede Minute |
23:14–23:15 Uhr – 5 Schritte/Minute 23:16–23:17 – 22 Schritte/Minute 23:17 – 23:18 – 8 Schritte/Minute |
Rollstuhlanschübe |
Anschübe |
Jede Minute |
23:14–23:15 Uhr – 5 Pushes 23:16–23:17 – 22 Schritte 23:17–23:18 – 8 Pushes |
ActiveCaloriesBurned |
Kalorien |
Alle 15 Minuten |
23:15–23:30 – 2 Kalorien 23:30–23:45 Uhr: 25 Kalorien 23:45–00:00 – 5 Kalorien |
TotalCaloriesBurned |
Kalorien |
Alle 15 Minuten |
23:15–23:30 – 16 Kalorien 23:30–23:45 – 16 Kalorien 23:45–00:00 – 16 Kalorien |
Entfernung |
km/min |
Jede Minute |
23:14–23:15 Uhr – 0,008 km 23:16 – 23:16 – 0,021 km 23:17 – 23:18 – 0,012 km |
ElevationGained |
m |
Jede Minute |
20:36 – 20:37 – 3.048 m 20:39 – 20:40 – 3.048 m 23:23–23:24 – 9.144 m |
Bewältigte Stockwerke |
Stockwerke |
Jede Minute |
23:14–23:15 Uhr – 5 Etagen 23:16 – 23:16 – 22 Etagen 23:17 – 23:18 – 8 Etagen |
HeartRate |
bpm |
4‑mal pro Minute |
6:11:15 Uhr – 55 SPM 6:11:30 Uhr – 56 bpm 6:11:45 Uhr – 56 bpm 6:12:00 Uhr – 55 bpm |
HeartRateVariabilityRmssd |
ms |
Jede Minute |
6:11 Uhr – 23 ms |
RespiratoryRate |
Atemzüge/Minute |
Jede Minute |
23:14 – 23:15 – 60 Atemzüge pro Minute 23:16 – 23:16 – 62 Atemzüge/Minute 23:17 – 23:18 – 64 Atemzüge/Minute |
OxygenSaturation |
% |
Stündlich |
6:11 – 95,208% |
Daten sollten am Ende des Trainings oder der Schlafsitzung in Health Connect geschrieben werden. Bei der aktiven Aufzeichnung, z. B. von Training und Schlaf, oder bei manuellen Nutzereingaben wie Ernährung werden diese Datensätze erstellt, wenn die App im Vordergrund ist oder in seltenen Fällen, wenn sie mehrmals am Tag verwendet wird.
Prüfen Sie, ob Ihre App Health Connect nicht für die gesamte Dauer des Ereignisses im Hintergrund ausführt.
Daten müssen auf eine der folgenden Arten in Health Connect geschrieben werden:
- Synchronisiere Daten mit Health Connect, nachdem das Ereignis abgeschlossen ist. Synchronisieren Sie beispielsweise Daten, wenn der Nutzer eine aufgezeichnete Trainingseinheit beendet.
- Planen Sie mit WorkManager eine einmalige Aufgabe, um Daten später zu synchronisieren.
Trainingseinheiten und Schlafeinheiten
Ihre Anwendung sollte mindestens den Richtlinien in der Spalte Erwartet in Tabelle 2 entsprechen. Folgen Sie nach Möglichkeit der Anleitung in der Spalte Best (Beste Lösung).
In der folgenden Tabelle sehen Sie, wie Sie während eines Trainings Daten schreiben:
Datentyp |
Einheit |
Erwartet |
Viele Grüße |
Beispiel |
Schritte |
Schritte |
Jede Minute |
Jede Sekunde |
23:14–23:15 – 5 Schritte 23:16 – 23:17 – 22 Schritte 23:17 – 23:18 – 8 Schritte |
StepsCadence |
Schritte/min |
Jede Minute |
Jede Sekunde |
23:14–23:15 Uhr – 35 Schritte/Minute 23:16–23:17 – 37 Schritte/Minute 23:17–23:18 – 40 Schritte/Minute |
Rollstuhlanschübe |
Anschübe |
Jede Minute |
Jede Sekunde |
23:14–23:15 Uhr – 5 Pushes 23:16–23:17 – 22 Schritte 23:17–23:18 – 8 Pushes |
CyclingPedalingCadence |
Atemzüge/Min. |
Jede Minute |
Jede Sekunde |
23:14–23:15 Uhr: 65 rpm 23:16 – 23:17 – 70 rpm 23:17 – 23:18 – 68 rpm |
Stromversorgung |
Watt |
Jede Minute |
Jede Sekunde |
23:14–23:15 – 250 Watt 23:16 – 23:17 – 255 Watt 23:17 – 23:18 – 245 Watt |
Geschwindigkeit |
km/min |
Jede Minute |
Jede Sekunde |
23:14–23:15 – 0,3 km/min 23:16–23:17 – 0,4 km/min 23:17 – 23:18 –0,4 km/min |
Entfernung |
km/m |
Jede Minute |
Jede Sekunde |
23:14–23:15 Uhr – 0,008 km 23:16 – 23:16 – 0,021 km 23:17 – 23:18 – 0,012 km |
ActiveCaloriesBurned |
Kalorien |
Jede Minute |
Jede Sekunde |
23:14–23:15 – 20 kcal 23:16–23:17 – 20 Kalorien 23:17 – 23:18 – 25 Kalorien |
TotalCaloriesBurned |
Kalorien |
Jede Minute |
Jede Sekunde |
23:14–23:15 – 36 Kalorien 23:16 – 23:17 – 36 Kalorien 23:17 – 23:18 – 41 Kalorien |
ElevationGained |
m |
Jede Minute |
Jede Sekunde |
20:36 – 20:37 – 3.048 m 20:39 – 20:40 – 3.048 m 23:23–23:24 – 9.144 m |
ExerciseRoutes |
lat/lng/alt |
Alle 3–5 Sekunden |
Jede Sekunde |
|
HeartRate |
bpm |
4‑mal pro Minute |
Jede Sekunde |
23:14–23:15 – 150 bpm |
In Tabelle 3 siehst du, wie du Daten während oder nach einer Schlafeinheit schreibst:
Datentyp |
Einheit |
Erwartete Stichproben |
Beispiel |
Schlafphasen |
Phase |
Detaillierter Zeitraum pro Schlafphase |
23:46–23:50 Uhr: wach 23:50 – 23:56 Uhr: Leichtschlaf 23:56 – 00:16 – Tiefschlaf |
Ruhepuls |
bpm |
Einzelner Tageswert (wird gleich morgens erwartet) |
6:11 Uhr – 60 bpm |
OxygenSaturation |
% |
Einzelner Tageswert (wird gleich morgens erwartet) |
6:11 – 95,208% |
Mehrdisziplin-Wettkämpfe
Bei diesem Ansatz werden vorhandene Datentypen und ‑strukturen verwendet und die Kompatibilität mit aktuellen Health Connect-Implementierungen und Datenlesern wird überprüft. Das ist ein gängiger Ansatz von Fitnessplattformen.
Außerdem sind einzelne Trainingseinheiten wie Schwimmen, Radfahren und Laufen nicht von Natur aus in Health Connect verknüpft. Datenleser müssen die Beziehung zwischen diesen Trainingseinheiten anhand ihrer zeitlichen Nähe ableiten. Übergänge zwischen Segmenten, z. B. von Schwimmen zu Radfahren, werden nicht explizit dargestellt.
Im folgenden Beispiel wird gezeigt, wie Daten für einen Triathlon geschrieben werden:
val swimStartTime = Instant.parse("2024-08-22T08:00:00Z") val swimEndTime = Instant.parse("2024-08-22T08:30:00Z") val bikeStartTime = Instant.parse("2024-08-22T08:40:00Z") val bikeEndTime = Instant.parse("2024-08-22T09:40:00Z") val runStartTime = Instant.parse("2024-08-22T09:50:00Z") val runEndTime = Instant.parse("2024-08-22T10:20:00Z") val swimSession = ExerciseSessionRecord( startTime = swimStartTime, endTime = swimEndTime, exerciseType = ExerciseSessionRecord.EXERCISE_TYPE_SWIMMING_OPEN_WATER, metadata = Metadata( device = Device(type = Device.TYPE_WATCH) ), startZoneOffset = null, endZoneOffset = null, ) val bikeSession = ExerciseSessionRecord( startTime = bikeStartTime, endTime = bikeEndTime, exerciseType = ExerciseSessionRecord.EXERCISE_TYPE_BIKING, metadata = Metadata( device = Device(type = Device.TYPE_WATCH) ), startZoneOffset = null, endZoneOffset = null, ) val runSession = ExerciseSessionRecord( startTime = runStartTime, endTime = runEndTime, exerciseType = ExerciseSessionRecord.EXERCISE_TYPE_RUNNING, metadata = Metadata( device = Device(type = Device.TYPE_WATCH) ), startZoneOffset = null, endZoneOffset = null, ) healthConnectClient.insertRecords(listOf(swimSession, bikeSession, runSession))
Ausnahmen behandeln
Health Connect löst Standardausnahmen für CRUD-Vorgänge aus, wenn ein Problem auftritt. Ihre App sollte jede dieser Ausnahmen abfangen und angemessen behandeln.
Für jede Methode in HealthConnectClient werden die Ausnahmen aufgeführt, die ausgelöst werden können.
Im Allgemeinen sollte Ihre App die folgenden Ausnahmen abfangen:
| Ausnahme | Beschreibung | Empfohlene Best Practice |
|---|---|---|
IllegalStateException
| Eines der folgenden Szenarien ist eingetreten:
| Beheben Sie zuerst mögliche Probleme mit den Eingaben, bevor Sie eine Anfrage senden. Weisen Sie Variablen vorzugsweise Werte zu oder verwenden Sie sie als Parameter in einer benutzerdefinierten Funktion, anstatt sie direkt in Ihren Anfragen zu verwenden, damit Sie Strategien zur Fehlerbehandlung anwenden können. |
IOException
| Beim Lesen und Schreiben von Daten auf die Festplatte sind Probleme aufgetreten. | Hier sind einige Vorschläge, wie Sie dieses Problem vermeiden können:
|
RemoteException
| Es sind Fehler im zugrunde liegenden Dienst aufgetreten, mit dem das SDK verbunden ist, oder bei der Kommunikation mit diesem Dienst. Ihre App versucht beispielsweise, einen Datensatz mit einer bestimmten uid zu löschen. Die Ausnahme wird jedoch erst ausgelöst, nachdem die App durch Überprüfung im zugrunde liegenden Dienst festgestellt hat, dass der Datensatz nicht vorhanden ist.
| Hier sind einige Vorschläge, wie Sie dieses Problem vermeiden können:
|
SecurityException
| Es treten Probleme auf, wenn für die Anfragen Berechtigungen erforderlich sind, die nicht erteilt wurden. | Um dies zu vermeiden, müssen Sie die Verwendung von Health Connect-Datentypen für Ihre veröffentlichte App deklarieren. Außerdem müssen Sie Health Connect-Berechtigungen in der Manifestdatei und in Ihrer Aktivität deklarieren. |