首页 > 解决方案 > 如何使用 Google Fit API 获取各种健身活动的读数?

问题描述

Google Fit API 中有各种健身活动,例如健美操、羽毛球、拳击、举重等。如何使用 Google Fit API 获取每项活动的步数读数和燃烧的卡路里?任何形式的建议都是最受欢迎的。提前致谢。

标签: androidgoogle-fit

解决方案


我不确定这个结果是否是你需要的。您可以使用bucketByActivitySegementunderDataReadRequest.Builder来拆分每个活动段。

    DataReadRequest readRequest = new DataReadRequest.Builder()
            .aggregate(DataType.TYPE_STEP_COUNT_DELTA, DataType.AGGREGATE_STEP_COUNT_DELTA)
            .aggregate(DataType.TYPE_CALORIES_EXPENDED, DataType.AGGREGATE_CALORIES_EXPENDED)
            .bucketByActivitySegment( 1, TimeUnit.MINUTES) // just segement time over 1 minute will be list 
            .setTimeRange(startTimeLong, endTimeLong, TimeUnit.MILLISECONDS)
            .enableServerQueries()
            .build();

    Fitness.getHistoryClient(context, GoogleSignIn.getLastSignedInAccount(context))
           .readData(readRequest)
           .addOnSuccessListener()
           .addOnFailureListener();

结果你会得到几个桶,每个桶是一个活动段。一个桶包含两个数据集。一个是步数值,另一个是卡路里值。就像下面这样:

Bucket 0: activity: still, 05/09 00:00~08:03
-DataSet 0:  
--DataPoint 0: 05/09 08:02~09:03
---Field name: steps, value: 55
-DataSet 1: 
--DataPoint 0: 05/09 00:00~08:03
---Field name: calories, value: 459.41046

Bucket 1: acitvity: walking, 05/09 08:03~08:09
-DataSet 0:
--DataPoint 0: 05/09 08:03~08:04
---Field name: steps, value: 181
-DataSet: 1
--DataPoint 0: 05/09 08:03~08:09
---Field name: calories, value: 20.808548

Bucket 2: activity: in_vehicle, 05/09 08:09~08:48
-DataSet 0:
--DataPoint 0: 05/09 08:33~08:38
---Field name: steps, value: 156
-DataSet 1:
--DataPoint 0: 05/09 08:09~08:48
---Field name: calories, value: 36.633526

Bucket 3: activity: walking, 05/09 08:48~09:12
...
...
...

如果您需要的结果是在持续时间内每种类型的聚合值,则可以使用bucketByActivityType.

    DataReadRequest readRequest = new DataReadRequest.Builder()
            .aggregate(DataType.TYPE_STEP_COUNT_DELTA, DataType.AGGREGATE_STEP_COUNT_DELTA)
            .aggregate(DataType.TYPE_CALORIES_EXPENDED, DataType.AGGREGATE_CALORIES_EXPENDED)
            .bucketByActivityType( 1, TimeUnit.MINUTES)
            .setTimeRange(startTimeLong, endTimeLong, TimeUnit.MILLISECONDS)
            .enableServerQueries()
            .build();

它将在您的 TimeRange 期间返回每种类型的总值。

Bucket 0: activity: still, 05/09 00:00 ~ 05/16 18:42
-DataSet 0:  
--DataPoint 0: 05/09 00:00 ~ 05/16 18:42
---Field name: calories, value: 9984.753
-DataSet 1: 
--DataPoint 0: 05/09 08:02 ~ 05/16 17:24
---Field name: steps, value: 6499

Bucket 1: acitvity: walking, 05/09 08:03 ~ 05/16 13:28
-DataSet 0:
--DataPoint 0: 05/09 08:03 ~ 05/16 13:28
---Field name: calories, value: 1214.7212
-DataSet: 1
--DataPoint 0: 05/09 08:03 ~ 05/16 13:20
---Field name: steps, value: 12750

Bucket 2: activity: in_vehicle, 05/09 08:09 ~ 05/09 08:48
-DataSet 0:
--DataPoint 0: 05/09 08:09 ~ 05/09 08:48
---Field name: calories, value: 36.633526
-DataSet 1:
--DataPoint 0: 05/09 08:33 ~ 05/09 08:38
---Field name: steps, value: 156

Bucket 3: activity: aerobics, 05/11 18:00 ~ 05/11 18:59
...
...
...

希望这对您有所帮助。


--- 2018/05/30 更新 ---

addOnSuccessListener()可以像这样添加一个监听器:

    new OnSuccessListener<DataReadResponse>() {
                @Override
                public void onSuccess(DataReadResponse dataReadResult) {
                    String returnValue = "";

                    if (dataReadResult.getBuckets().size() > 0) {
                        for (int i = 0; i < dataReadResult.getBuckets().size(); i++) {
                            returnValue += "\n\n" + i + " ---new bucket-- activity: " + dataReadResult.getBuckets().get(i).getActivity() + "\n"
                                    + getNoYearDateWithTimeFormat().format(dataReadResult.getBuckets().get(i).getStartTime(TimeUnit.MILLISECONDS)) + "~"
                                    + getNoYearDateWithTimeFormat().format(dataReadResult.getBuckets().get(i).getEndTime(TimeUnit.MILLISECONDS));

                            for (int j = 0; j < dataReadResult.getBuckets().get(i).getDataSets().size(); j++) {
                                returnValue += "\n-data set " + j + "-package: " + dataReadResult.getBuckets().get(i).getDataSets().get(j).getDataSource().getAppPackageName() + ", stream: " + dataReadResult.getBuckets().get(i).getDataSets().get(j).getDataSource().getStreamIdentifier();
                                returnValue += handleDailyRecordInDataSet(dataReadResult.getBuckets().get(i).getDataSets().get(j));
                            }
                        }
                    }


                    if (fitnessListener != null) {
                        fitnessListener.readActionDone(null, returnValue);
                    }
                }
            }

在每个存储桶中,您可以获得每种数据类型的多个 DataSet。

private String handleDailyRecordInDataSet(DataSet dataSet) {
    String returnValue = "";

    for (DataPoint dataPoint : dataSet.getDataPoints()) {
        long startTime = dataPoint.getStartTime(TimeUnit.MILLISECONDS);
        long endTime = dataPoint.getEndTime(TimeUnit.MILLISECONDS);
        String tempValue = "DataPoint start: " + getDateWithTimeFormat().format(new Date(startTime))
                + ", end=" + getDateWithTimeFormat().format(new Date(endTime))
                + ", type=" + dataPoint.getDataType().getName() + ",  package=" + dataPoint.getDataSource().getAppPackageName() + ", stream=" + dataPoint.getDataSource().getStreamIdentifier();
        if (dataPoint.getDataSource().getDevice() != null) {
            tempValue += "\nManufacturer=" + dataPoint.getDataSource().getDevice().getManufacturer() + ", model=" + dataPoint.getDataSource().getDevice().getModel()
                    + ", uid: " + dataPoint.getDataSource().getDevice().getUid() + ", type=" + dataPoint.getDataSource().getDevice().getType();
        }
        tempValue += "\norigin source: package=" + dataPoint.getOriginalDataSource().getAppPackageName() + ", stream=" + dataPoint.getOriginalDataSource().getStreamIdentifier();
        if (dataPoint.getOriginalDataSource().getDevice() != null) {
            tempValue += "\nManufacturer=" + dataPoint.getOriginalDataSource().getDevice().getManufacturer() + ", model=" + dataPoint.getOriginalDataSource().getDevice().getModel()
                    + ", uid: " + dataPoint.getOriginalDataSource().getDevice().getUid() + ", type=" + dataPoint.getOriginalDataSource().getDevice().getType();
        }

        returnValue += ("\n\n" + tempValue);
        for (Field field : dataPoint.getDataType().getFields()) {
            String fieldValue = "Field name: " + field.getName() + ", value: " + dataPoint.getValue(field);

            returnValue += ("\n" + fieldValue);
        }
    }

    return returnValue;
}

推荐阅读