如何让 DataLogger 从 Android 应用程序工作

How to get DataLogger working from Android App

我们正在为 MoveSense 开发一款应用程序,可以在某些特定情况下跟踪用户的移动。然而,由于我们的环境,蓝牙连接可能会间歇性中断。为了不丢失任何数据,我们希望将传感器数据存储在 MoveSense 上,并在连接恢复后读取它。在文档中我们找到了 DataLogger 接口,但我们在使用它时遇到了问题。

在我们的 Android 应用程序中,我们首先订阅了我们想要的传感器(目前只有陀螺仪,但一旦我们启动了陀螺仪和 运行,我们将扩展以包括加速度计)。 为此,我们执行一个 put 命令:

Mds put() uri: suunto://<SERIAL>/Mem/DataLogger/Config contract: {"config": { "dataEntries": {"dataEntry": [{"path": "/Meas/Gyro/13"}]}}}

此命令使用“200”代码接受(找出正确的 JSON 也花了一些时间,因为文档缺少 'config' 部分并且使用了完全不同的路径)。

在此之后我们尝试激活记录器:

Mds put() uri: suunto://<SERIAL>/Mem/DataLogger/State contract: {"newState": 5}

但是在这个命令上我们得到一个“403”(禁止)错误返回:

[SDS RESPONSE] type: PUT status: FORBIDDEN header: {"Status": 403, "TaskId": 28, "Reason": "FORBIDDEN", "Uri": "suunto://<SERIAL>/Mem/DataLogger/State", "Content-Length": 0}

我们做错了什么?配置中是否有错误?我们是否忘记了其他一些操作?

请注意,我们确保在启用了 DataLoger 和 Logbook 模块的 MoveSense 上刷新应用程序。

开始记录之前的第一步,我们需要创建 DataLogger 配置。 加速度计和陀螺仪日志的配置示例。

{
    "dataEntries" : {
        "dataEntry" : [{
                "path" : "/Meas/Acc/13"
            }, {
                "path" : "/Meas/Gyro/13"
            }
        ]
    }
}

在 Android 示例中创建配置:

PATH: {serial}/Mem/DataLogger/Config/ REQUEST: PUT

 Mds.builder().build(context).put("suunto://" + movesenseSerial + "/Mem/DataLogger/Config/",
                jsonConfig, new MdsResponseListener() {
                    @Override
                    public void onSuccess(String s) {
                    }

                    @Override
                    public void onError(MdsException e) {
                    }
                });

示例响应:

{"Content": {"dataEntries": {"dataEntry": [{"path": "/Meas/Acc/13"}, {"path": "/Meas/Gyro/13"}]}}}

配置准备就绪后,我们就可以开始记录了。 要开始记录,将值 DATALOGGER_LOGGING (=3) 放入 Mem/DataLogger/State 资源 Android 开始记录示例:

PATH: {serial}/Mem/DataLogger/State/ REQUEST: PUT

Mds.builder().build(context).put("suunto://" + movesenseSerial + /Mem/DataLogger/State/,
                "{\"newState\":3}", new MdsResponseListener() {
                    @Override
                    public void onSuccess(String data) {
                    }
                    @Override
                    public void onError(MdsException error) {
                    }
                });

示例响应:

{"Content": 3}

要停止记录,将值 DATALOGGER_READY (=2) 放入 Mem/DataLogger/State 资源 Android 停止记录示例:

PATH: {serial}/Mem/DataLogger/State/ REQUEST: PUT

Mds.builder().build(context).put("suunto://" + movesenseSerial + /Mem/DataLogger/State/,
                "{\"newState\":2}", new MdsResponseListener() {
                    @Override
                    public void onSuccess(String data) {
                    }
                    @Override
                    public void onError(MdsException error) {
                    }
                });

示例响应:

{"Content": 2}

创建日志文件后,我们可以从设备中获取所有条目/日志:

PATH: /MDS/Logbook/{serial}/Entries REQUEST: GET

Mds.builder().build(context).get("suunto://" + movesenseSerial + "/Mem/Logbook/Entries/",
                        null, new MdsResponseListener() {
                            @Override
                            public void onSuccess(String data) {
                            }

                            @Override
                            public void onError(MdsException error) {
                            }
                        });

示例响应:

{"elements": [{"Id": 1, "ModificationTimestamp": 536927972, "Size": null}, {"Id": 5, "ModificationTimestamp": 4446227, "Size": null}]}

当我们有条目时,我们可以阅读它们

PATH: /MDS/Logbook/{serial}/byId/{LogId}/Summary REQUEST: GET

Mds.builder().build(context).get("suunto://MDS/Logbook/" + movesenseSerial + "/byId/" + entryId + "/Data",
                        null, new MdsResponseListener() {
                            @Override
                            public void onSuccess(String data) {
                            }

                            @Override
                            public void onError(MdsException error) {
                            }
                        });