Este guia é compatível com a versão 1.1.0-rc01 da Conexão Saúde.
O app Conexão Saúde oferece um tipo de dados de atenção plena para medir vários aspectos da saúde mental, como estresse e ansiedade. Mindfulness é um tipo de dados que faz parte do bem-estar geral na Conexão Saúde.
Disponibilidade do recurso
Para determinar se o dispositivo de um usuário é compatível com registros de sessões de mindfulness no Conexão Saúde, verifique a disponibilidade deFEATURE_MINDFULNESS_SESSION
no cliente:
if (healthConnectClient
.features
.getFeatureStatus(
HealthConnectFeatures.FEATURE_MINDFULNESS_SESSION
) == HealthConnectFeatures.FEATURE_STATUS_AVAILABLE) {
// Feature is available
} else {
// Feature isn't available
}
Consulte Verificar a disponibilidade de recursos para saber mais.
Permissões necessárias
O acesso à prática de mindfulness é protegido pelas seguintes permissões:
android.permission.health.READ_MINDFULNESS
android.permission.health.WRITE_MINDFULNESS
Para adicionar a capability de atenção plena ao app, comece solicitando permissões de
gravação do tipo de dado MindfulnessSession
.
Confira a permissão necessária para poder gravar mindfulness:
<application>
<uses-permission
android:name="android.permission.health.WRITE_MINDFULNESS" />
...
</application>
Para ler a atenção plena, solicite as seguintes permissões:
<application>
<uses-permission
android:name="android.permission.health.READ_MINDFULNESS" />
...
</application>
Solicitar permissões do usuário
Depois de criar uma instância de cliente, seu app precisa solicitar permissões do usuário. Os usuários precisam poder conceder ou negar permissões a qualquer momento.
Para isso, crie um conjunto de permissões para os tipos de dados necessários. Verifique se as permissões no conjunto foram declaradas primeiro no manifesto do Android.
// Create a set of permissions for required data types
val PERMISSIONS =
setOf(
HealthPermission.getReadPermission(MindfulnessSessionRecord::class),
HealthPermission.getWritePermission(MindfulnessSessionRecord::class)
)
Use getGrantedPermissions
para verificar se o app já tem as
permissões necessárias concedidas. Caso contrário, use
createRequestPermissionResultContract
para solicitar
essas permissões. Isso mostra a tela de permissões da Conexão Saúde.
// 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 lidar com cenários em que a permissão é perdida.
Informações incluídas em um registro de sessão de mindfulness
Cada registro de sessão de atenção plena captura qualquer tipo de sessão realizada por um usuário, como meditação, respiração e movimento. O registro também pode incluir outras observações sobre a sessão.
Agregações compatíveis
Não há agregações compatíveis para esse tipo de dado.
Ler sessão de mindfulness
O snippet de código a seguir demonstra como ler uma sessão de atenção plena:
if (healthConnectClient.features.getFeatureStatus(FEATURE_MINDFULNESS_SESSION) == HealthConnectFeatures.FEATURE_STATUS_AVAILABLE) {
healthConnectClient.insertRecords(listOf(MindfulnessSessionRecord(
startTime = Instant.now().minus(Duration.ofHours(1)),
startZoneOffset = ZoneOffset.UTC,
endTime = Instant.now(),
endZoneOffset = ZoneOffset.UTC,
mindfulnessSessionType = MindfulnessSessionRecord.MINDFULNESS_SESSION_TYPE_MEDITATION,
title = "Lake meditation",
notes = "Meditation by the lake",
metadata = Metadata.activelyRecorded(
clientRecordId = "myid",
clientRecordVersion = 0.0,
device = Device(type = Device.TYPE_PHONE)
),
)))
}