2

我正在尝试每天从 Google Fit 获取步数数据以显示在我的应用程序中。我正在使用的代码似乎是正确的,因为我正在获取一些数据,但是当我比较我获得的 Google Fit 应用程序的数据时,这些数字还差得很远。例如,在 3 月 19 日的 Google Fit(无论是在网络上还是在 Android 应用程序中)中,它显示了 2269 步。在我 3 月 19 日的应用程序中,它显示了 64 个步骤。我在我的应用程序中获得的数据始终低于 10 的幂。我是否错误地请求数据?相关代码如下。

客户端生成器代码

GoogleApiClient.Builder builder = new GoogleApiClient.Builder(Main.instance)
                .addApi(Fitness.API)
                .addScope(new Scope(Scopes.FITNESS_ACTIVITY_READ));

请求构建器代码

private DataReadRequest queryFitnessData(long date)
{
    // Build a single day range.
    Calendar cal = Calendar.getInstance();
    cal.setTimeInMillis(date);
    cal.set(Calendar.HOUR_OF_DAY, 0);
    cal.set(Calendar.MINUTE, 0);
    cal.set(Calendar.SECOND, 0);
    cal.set(Calendar.MILLISECOND, 0);
    long startTime = cal.getTimeInMillis();
    cal.add(Calendar.DATE, 1);
    cal.add(Calendar.MILLISECOND, -1);
    long endTime = cal.getTimeInMillis();

    DataReadRequest readRequest = new DataReadRequest.Builder()
    .enableServerQueries()
    .aggregate(DataType.TYPE_STEP_COUNT_DELTA, DataType.AGGREGATE_STEP_COUNT_DELTA)
    .bucketByTime(1, TimeUnit.DAYS)
    .setTimeRange(startTime, endTime, TimeUnit.MILLISECONDS)
    .build();
    return readRequest;
}

执行查询

DataReadResult dataReadResult =
                        Fitness.HistoryApi.readData(googleClient, readRequest).await(1, TimeUnit.MINUTES);

if(dataReadResult.getBuckets().size() > 0)
{
    Bucket bucket = dataReadResult.getBuckets().get(0);
    for(DataSet dataSet : bucket.getDataSets())
    {
        for(DataPoint dp : dataSet.getDataPoints())
        {
            if(dp.getDataType().equals(DataType.TYPE_STEP_COUNT_DELTA))
            {
                for(Field field : dp.getDataType().getFields())
                {
                    if(field.getName().equals(Field.FIELD_STEPS.getName()))
                    {
                        if(listener != null)
                        {
                            listener.onStepCount(dp.getValue(field).asInt());
                        }
                    }
                }
            }
        }
    }
}
4

1 回答 1

0

我可能会尝试的第一件事是摆脱 enableServerQueries() 并查询本地数据,这可能是同步时间问题。

除此之外,如果没有看到 dataReadResult 中返回的其他一些数据,就很难分辨。我很想放一些 Log 语句来看看发生了什么。

我的代码如下所示,对我有用

for (Bucket bucket : dataReadResult.getBuckets()) {

    Log.d(TAG, "Bucket start time: " + bucket.getStartTime(TimeUnit.SECONDS));

    List<DataSet> dataSets = bucket.getDataSets();

    totalStepsValue = 0;

    for (DataSet dataSet : dataSets) {
        for (DataPoint dp : dataSet.getDataPoints()) {
            for (Field field : dp.getDataType().getFields()) {
                if (field.getName().equals("steps")) {
                    totalStepsValue += dp.getValue(field).asInt();
                } 
            }
        }
    }

    Log.d(TAG, "totalStepsValue: " + totalStepsValue);
}

还可以尝试使用 30 分钟的存储桶获取一天的数据,看看是否有任何不同。

于 2015-04-09T19:04:01.323 回答