Odczytaj sumę dziennych kroków

W tej sekcji pokazujemy, jak odczytać bieżące dane o dziennej liczbie kroków za pomocą interfejsu Fit Android API i interfejsu Fit REST API.

Android

Aplikacja może odczytać łączną liczbę kroków z danego dnia, wywołując funkcję HistoryClient.readDailyTotal, jak pokazano w tym przykładzie:

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)
    }

Dzienna suma jest obliczana od północy bieżącego dnia według strefy czasowej urządzenia.

Aby uzyskać taką samą liczbę kroków dziennie jak w aplikacji Fit, utwórz źródło danych za pomocą com.google.android.gmspakietu aplikacji, jak pokazano w tym przykładzie:

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")
    }

Więcej informacji o pracy ze zagregowanymi źródłami danych znajdziesz w artykule Praca z historią aktywności.

REST

Aplikacja może odczytać łączną liczbę kroków z bieżącego dnia ze wszystkich źródeł danych, wysyłając żądanie POST i wykonując zapytanie o typ danych com.google.step_count.delta w określonym przedziale czasu.

Metoda HTTP

POST

Adres URL żądania

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

Treść żądania

{
  "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
}

Polecenie 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