如何让 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) {
}
});
我们正在为 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) {
}
});