Ler o total de passos por dia

Esta seção demonstra a leitura de dados atuais de contagem de passos usando a API Fit Android e a API REST do Fit.

Android

Seu app pode ler o total diário atual das etapas chamando HistoryClient.readDailyTotal, conforme mostrado no exemplo a seguir:

Fitness.getHistoryClient(this, GoogleSignIn.getAccountForExtension(this, fitnessOptions))
    .readDailyTotal(DataType.TYPE_STEP_COUNT_DELTA)
    .addOnSuccessListener { result ->
        val totalSteps =
            result.dataPoints.firstOrNull()?.getValue(Field.FIELD_STEPS)?.asInt() ?: 0
        // Do something with totalSteps
    }
    .addOnFailureListener { e ->
        Log.i(TAG, "There was a problem getting steps.", e)
    }

O total diário é calculado a partir da meia-noite do dia atual no fuso horário atual do dispositivo.

Para ter a mesma contagem diária de passos que o app Fit, crie uma fonte de dados usando o pacote de app com.google.android.gms, conforme mostrado no exemplo a seguir:

val startTime = LocalDate.now().atStartOfDay(ZoneId.systemDefault())
val endTime = LocalDateTime.now().atZone(ZoneId.systemDefault())

val datasource = DataSource.Builder()
    .setAppPackageName("com.google.android.gms")
    .setDataType(DataType.TYPE_STEP_COUNT_DELTA)
    .setType(DataSource.TYPE_DERIVED)
    .setStreamName("estimated_steps")
    .build()

val request = DataReadRequest.Builder()
    .aggregate(datasource)
    .bucketByTime(1, TimeUnit.DAYS)
    .setTimeRange(startTime.toEpochSecond(), endTime.toEpochSecond(), TimeUnit.SECONDS)
    .build()

Fitness.getHistoryClient(this, GoogleSignIn.getAccountForExtension(this, fitnessOptions))
    .readData(request)
    .addOnSuccessListener { response ->
        val totalSteps = response.buckets
            .flatMap { it.dataSets }
            .flatMap { it.dataPoints }
            .sumBy { it.getValue(Field.FIELD_STEPS).asInt() }
        Log.i(TAG, "Total steps: $totalSteps")
    }

Para saber mais sobre como trabalhar com fontes de dados agregadas, consulte Trabalhar com o histórico de condicionamento físico.

REST

Seu app pode ler a contagem total atual de passos por dia em todas as fontes de dados fazendo uma solicitação POST e consultando o tipo de dados com.google.step_count.delta para o período especificado.

Método HTTP

POST

Request URL

https://www.googleapis.com/fitness/v1/users/me/dataset:aggregate

Corpo da solicitação

{
  "aggregateBy": [{
    "dataTypeName": "com.google.step_count.delta",
    "dataSourceId": "derived:com.google.step_count.delta:com.google.android.gms:estimated_steps"
  }],
  "bucketByTime": { "durationMillis": 86400000 },
  "startTimeMillis": 1438705622000,
  "endTimeMillis": 1439310422000
}

Comando Curl

curl \
-X POST \
-H "Content-Type: application/json;encoding=utf-8" \
-H "Authorization: Bearer $ACCESS_TOKEN" \
-d @aggregate.json \
https://www.googleapis.com/fitness/v1/users/me/dataset:aggregate