如何让数据记录器从Android应用程序工作



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

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

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

此命令使用"200"代码接受(找出正确的 JSON 也需要一些时间,因为文档缺少"配置"部分并使用完全不同的路径)。

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

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

在安卓中创建配置示例:

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

当配置准备就绪时,我们可以开始日志记录。 要开始记录,PUT 值DATALOGGER_LOGGING (=3) 到 Mem/DataLogger/State 资源 安卓开始记录示例:

路径: {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}

要停止日志记录,PUT 值DATALOGGER_READY (=2) 到 Mem/DataLogger/State 资源 安卓停止记录示例:

路径: {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}

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

路径:/

MDS/Logbook/{serial}/Entries 请求: 获取

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

相关内容

最新更新