我正在尝试从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());
}
}
}
}
}
}
}
我可能会尝试的第一件事是摆脱enableServerQueries()并查询本地数据,这可能是一个同步时间问题。
除此之外,如果不看到DataReadResult中返回的其他数据,就很难判断。我很想放几个日志语句,看看发生了什么。
我的代码如下所示,它适用于我
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分钟桶获取一天的数据,看看是否得到了不同的结果。