Este guia é compatível com a versão 1.1.0-alpha12 do Health Connect.
O app Conexão Saúde oferece um tipo de dados de temperatura da pele para medir a temperatura periférica do corpo. Essa medição é um indicador particularmente útil para detectar a qualidade do sono, a saúde reprodutiva e o possível início de uma doença.
Permissões necessárias
Como acontece com qualquer tipo de dados na Conexão Saúde, o acesso à temperatura da pele é protegido
por um par de permissões: READ_SKIN_TEMPERATURE
e
WRITE_SKIN_TEMPERATURE
.
Solicitar permissões do usuário
Depois de criar uma instância de cliente, seu app precisa solicitar permissões ao usuário. Os usuários precisam ter permissão para conceder ou negar permissões a qualquer momento.
Para fazer isso, crie um conjunto de permissões para os tipos de dados necessários. Verifique se as permissões no conjunto foram declaradas no manifesto do Android primeiro.
// Create a set of permissions for required data types
val PERMISSIONS =
setOf(
HealthPermission.getReadPermission(SkinTemperatureRecord::class),
HealthPermission.getWritePermission(SkinTemperatureRecord::class)
)
Use getGrantedPermissions
para conferir se o app já tem as
permissões necessárias. Caso contrário, use
createRequestPermissionResultContract
para solicitar
essas permissões. A tela de permissões da Conexão Saúde será exibida.
// Create the permissions launcher
val requestPermissionActivityContract = PermissionController.createRequestPermissionResultContract()
val requestPermissions = registerForActivityResult(requestPermissionActivityContract) { granted ->
if (granted.containsAll(PERMISSIONS)) {
// Permissions successfully granted
} else {
// Lack of required permissions
}
}
suspend fun checkPermissionsAndRun(healthConnectClient: HealthConnectClient) {
val granted = healthConnectClient.permissionController.getGrantedPermissions()
if (granted.containsAll(PERMISSIONS)) {
// Permissions already granted; proceed with inserting or reading data
} else {
requestPermissions.launch(PERMISSIONS)
}
}
Como os usuários podem conceder ou revogar permissões a qualquer momento, seu app precisa verificar periodicamente as permissões concedidas e processar cenários em que a permissão é perdida.
Informações incluídas em um registro de temperatura da pele
As medições de temperatura da pele são organizadas em registros. Cada registro consiste nas seguintes informações:
- Temperatura de referência, em graus Celsius ou Fahrenheit. Esse é um valor opcional mais útil para visualização na interface do app.
- Uma lista de deltas na temperatura da pele, cada uma mostrando a mudança na temperatura da pele desde a última medição. Se a temperatura de referência for fornecida, esses deltas precisarão usar as mesmas unidades de temperatura.
- O local no corpo do usuário em que a medição foi feita: dedo, pé ou pulso.
Agregações compatíveis
A Conexão Saúde permite que você receba os seguintes valores agregados para uma determinada lista de deltas:
- Valor mínimo
- Valor máximo
- Valor médio
Ler temperatura da pele
O snippet de código abaixo mostra como ler as medições de temperatura da pele usando a biblioteca 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.
}
}
Gravar temperatura da pele
O snippet de código abaixo mostra como gravar medições de temperatura da pele usando a biblioteca 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)
healthConnectClient.insertRecords(
// For this example, there's only one skin temperature record.
listOf(
SkinTemperatureRecord(
baseline = Temperature.celsius(37.0),
startTime = recordStartTime.toInstant(),
startZoneOffset = recordStartTime.offset,
endTime = recordEndTime.toInstant(),
endZoneOffset = recordEndTime.offset,
deltas = listOf(
SkinTemperatureRecord.Delta(
recordEndTime.minusMinutes(50).toInstant(), celsius(0.5)
), SkinTemperatureRecord.Delta(
recordEndTime.minusMinutes(30).toInstant(), celsius(-0.7)
)
),
measurementLocation = SkinTemperatureRecord.MEASUREMENT_LOCATION_FINGER,
metadata = Metadata.autoRecorded(
device = Device(type = Device.TYPE_RING)
),
)
)
)
}