Health Connect udostępnia typ danych temperatura skóry do pomiaru temperatury obwodowej ciała. Ten pomiar jest szczególnie przydatnym sygnałem w przypadku wykrywania jakości snu, zdrowia reprodukcyjnego i potencjalnego początku choroby.
Wymagane uprawnienia
Podobnie jak w przypadku innych typów danych w Health Connect, dostęp do temperatury skóry jest chroniony przez 2 uprawnienia: READ_SKIN_TEMPERATURE
i WRITE_SKIN_TEMPERATURE
.
Informacje zawarte w rekordzie temperatury skóry
Pomiary temperatury skóry są zorganizowane w rekordy. Każdy rekord zawiera te informacje:
- Temperatura bazowa w stopniach Celsjusza lub Fahrenheita. To wartość opcjonalna najbardziej przydatna przy wizualizacji w interfejsie aplikacji.
- Lista różnic temperatury skóry, z których każda pokazuje zmianę temperatury skóry od ostatniego pomiaru. Jeśli podana jest temperatura bazowa, te różnice powinny być wyrażone w tych samych jednostkach temperatury.
- Lokalizacja na ciele użytkownika, w której wykonano pomiar: palec u palca lub nadgarstka.
Obsługiwane agregacje
Zarządzanie danymi o zdrowiu umożliwia uzyskanie tych wartości zbiorczych dla danej listy różnic:
- Wartość minimalna
- Wartość maksymalna
- Średnia wartość
Odczytuj temperaturę skóry
Ten fragment kodu pokazuje, jak odczytywać pomiary temperatury skóry za pomocą biblioteki Jetpack:
suspend fun readSkinTemperatures() {
// Error handling, permission check, and feature availability check
// aren't included.
// Record includes measurements during the past hour.
val recordEndTime = Instant.now()
val recordStartTime = recordEndTime.minusSeconds(60 * 60)
val response = healthConnectClient.readRecords(
ReadRecordsRequest<SkinTemperatureRecord>(
timeRangeFilter = TimeRangeFilter.between(
recordStartTime, recordEndTime)
)
)
for (skinTemperatureRecord in response.records) {
// Process each skin temperature record here.
}
}
Zapisuj temperaturę ciała
Ten fragment kodu pokazuje, jak pisać pomiary temperatury skóry za pomocą biblioteki Jetpack:
suspend fun writeSkinTemperatures(): InsertRecordsResponse {
// Error handling, permission check, and feature availability check
// aren't included.
// Record includes measurements during the past hour.
val recordEndTime: ZonedDateTime = now()
val recordStartTime: ZonedDateTime = recordEndTime.minusHours(1)
return healthConnectClient.insertRecords(
// For this example, there's only one skin temperature record.
listOf(
SkinTemperatureRecord(
startTime = recordStartTime.toInstant(),
startZoneOffset = recordStartTime.offset,
endTime = recordEndTime.toInstant(),
endZoneOffset = recordEndTime.offset,
deltas = listOf(
SkinTemperatureRecord.Delta(
recordEndTime.minusMinutes(50), celsius(0.5)),
SkinTemperatureRecord.Delta(
recordEndTime.minusMinutes(30), celsius(-0.7))
),
measurementLocation =
SkinTemperatureRecord.MEASUREMENT_LOCATION_FINGER
)
)
)
}