Esta seção demonstra a leitura dos dados atuais de contagem de passos diários usando o Fit API Android e API REST do Fit.
Android
Seu app pode ler o total atual de passos diários chamando
HistoryClient.readDailyTotal
,
conforme mostrado neste exemplo:
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 sistema fuso horário atual.
Para ter a mesma contagem diária de passos do app Fit, crie uma fonte de dados usando:
o pacote de apps 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 mais informações sobre como trabalhar com fontes de dados agregados, consulte Trabalhar com o Histórico de condicionamento físico.
REST
Seu app pode ler a contagem atual de passos diários em todos os dados
fontes de dados fazendo uma solicitação POST
e consultando
com.google.step_count.delta
tipo de dados 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