告警信息是一个常用的功能,MCU 在设备异常时,会发送告警信息到串口屏,串口屏可以显示告警信息,也可以对告警信息进行管理(保存或清除)。
基本工作原理:
1.MCU 端设置属性名为 log_message,数据类型为字符串,数据格式为 "告警级别|时间|设备|告警信息"数据。
告警级别可以是:调试 (0); 信息 (1); 警告 (2); 错误 (3)
告警信息中如果出现 “|” 字符,则整个告警信息需用用英文双引号引起来。
时间为 epoch 时间,方便内部存储和查询。
下面演示一下具体的实现方法。
从模板创建项目,将 hmi/template_app 拷贝 hmi/log_message 即可。
第一个项目最好不要放到其它目录,因为放到其它目录需要修改配置文件中的路径,等熟悉之后再考虑放到其它目录。路径中也不要中文和空格,避免不必要的麻烦。
用 AWStudio 打开上面 log_message 目录下的 project.json 文件。里面有一个空的窗口,在上面设计类似下面的界面:
中间是一个列表视图,列表视图中放一个列表项,列表项中放 5 个文本控件,分别用来显示序数、告警级别、时间、设备、告警信息。
第一次用到列表视图,有几点需要特别说明一下:
列表视图中的滚动视图需要指定 v-for-items 属性:
属性 | 值 | 说明 |
---|---|---|
v-for-items | true | 它保证其下的列表项,会根据数据自动生成| |
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-data:value | {index} | index 特指序数。 |
前面提到告警级别是正数,可以通过 item.level 来获取它。它的意义对应为:调试 (0); 信息 (1); 警告 (2); 错误 (3),我们需要用 one_of 函数将它转换为对应的字符串。
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-data:value | {one_of(‘调试;信息;警告;错误’, item.level)} | 这里的 one_of 的功能是从指定的字符串数组中取出对应的子串。 |
时间是整数(秒数),可以通过 item.time 来获取。
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-data:value | {date_time_format(item.time, ‘Y-M-D h??s’)} | 需要用date_time_format将 epoch 时间转换成人类可读的时间。 |
设备是一个字符串,可以通过 item.device 来获取。
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-data:value | {item.device} |
告警信息是一个字符串,可以通过 item.message 来获取。
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-data:value | {item.message} |
为了配合删除选中的告警信息,需要在列表项加两个绑定规则。
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-on:click | {set_selected} | 点击时将当前项目设置为选中 |
v-data:focused | {index==selected_index} | 当前项目选中时高亮 |
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-on:click | {remove, Args=selected_index} | selected_index 表示当前选中的项目 |
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-on:click | {clear} |
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-on:click | {save} |
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-on:click | {reload} |
绑定属性 | 绑定规则 | 说明 |
---|---|---|
v-on:click | {nothing, QuitApp=true} |
修改 design/default/data/settings.json 文件,启用告警信息:
{
"name": "hmi_log_message1",
"log_message": {
"enable": true, /*是否启用告警信息*/
"fields": [
"level" /*告警级别*/,
"time" /*日期时间*/,
"device" /*设备*/,
"message" /*信息*/
],
"fields_seperator": "|", /*字段之间的分隔符*/
"max_rows": 1000 /*告警信息最大行数*/
}
}
运行 bin 目录下的 demo 程序。
运行 mcu/simulator 目录下的 mcu_sim 程序,连接到 Localhost:2233。
测试数据:
1|1702030398|大门|长时间没有关闭
本项目并没有编写界面相关的代码,AWStudio 在 src/pages 目录下生成了一些代码框架,这些代码并没有用到,可以删除也可以不用管它,但是不能加入编译。
实际使用时,在 demo_log_message/design/default/ui/home_page.xml 基础上进行调整即可,无需重复上面的过程,但是最好了解其中的原理。