AWTK 开源串口屏开发(4) - 采用数据

AWTK 开源串口屏开发 - 数据采集

1. 功能

数据采集是一个常用的功能,MCU 定时采集数据(如环保设备定时采样空气中的污染物),并发送采样数据到串口屏,串口屏可以显示采样数据,也可以对采样数据进行管理(保存或清除)。

在这里插入图片描述

基本工作原理:

  • 1.MCU 端设置属性名为 history_data,数据类型为字符串,数据格式为用 | 分隔的多个字段的数据。

  • 2.串口屏收到数据后,会把采样数据放到一个名为 history_data 的模型(数据)中。

  • 3.界面通过绑定规则将 history_data 模型中的数据关联到控件上。

在这里插入图片描述

时间为 epoch 时间,方便内部存储和查询。

下面演示一下具体的实现方法。

2. 创建项目

从模板创建项目,将 hmi/template_app 拷贝 hmi/history_data 即可。

第一个项目最好不要放到其它目录,因为放到其它目录需要修改配置文件中的路径,等熟悉之后再考虑放到其它目录。路径中也不要中文和空格,避免不必要的麻烦。

3. 制作界面

用 AWStudio 打开上面 history_data 目录下的 project.json 文件。里面有一个空的窗口,在上面设计类似下面的界面:

在这里插入图片描述

中间是一个列表视图列表视图中放一个列表项列表项中放 6 个文本控件,分别用来显示序数、时间、一氧化碳、二氧化氮、悬浮颗粒物、二氧化硫。

3. 添加绑定规则

第一次用到列表视图,有几点需要特别说明一下:

列表视图中的滚动视图需要指定 v-for-items 属性:

属性 说明
v-for-items true 它保证其下的列表项,会根据数据自动生成|

3.0.1 几个特殊的变量

  • index 特指序数。
  • item 特指当前的数据。比如在这里 ‘item.time’ 表示时间,‘item.一氧化碳’ 表示一氧化碳,‘item.二氧化氮’ 表示二氧化氮,‘item.悬浮颗粒物’ 表示悬浮颗粒物。
  • selected_index 表示当前选中的序数(可在列表视图之外绑定)。
  • items 表示当前列表视图中的数据个数(可在列表视图之外绑定)。

3.0.2 几个特殊的命令

  • set_selected 设置当前选中的序数(在列表项中使用)。
  • save 保存数据到文件(在列表视图之外的按钮上绑定)。
  • reload 重新加载数据(在列表视图之外的按钮上绑定)。
  • clear 清除所有数据(在列表视图之外的按钮上绑定)。
  • remove 删除指定序数的数据(在列表视图之外的按钮上绑定)。

3.1 序数

绑定属性 绑定规则 说明
v-data:value {index} index 特指序数。

3.2 时间

时间是整数(秒数),可以通过 item.time 来获取。

绑定属性 绑定规则 说明
v-data:value {date_time_format(item.time, ‘Y-M-D hⓂ️s’)} 需要用date_time_format将 epoch 时间转换成人类可读的时间。

3.3 一氧化碳

可以通过 item.一氧化碳 来获取。

绑定属性 绑定规则 说明
v-data:value {item.一氧化碳}

3.4 二氧化氮

可以通过 item.二氧化氮 来获取

绑定属性 绑定规则 说明
v-data:value {item.二氧化氮}

3.5 悬浮颗粒物

可以通过 item.悬浮颗粒物 来获取

绑定属性 绑定规则 说明
v-data:value {item.悬浮颗粒物}

3.6 二氧化硫

可以通过 item.二氧化硫 来获取

绑定属性 绑定规则 说明
v-data:value {item.二氧化硫}

3.7 列表项

为了配合删除选中的采样数据,需要在列表项加两个绑定规则。

绑定属性 绑定规则 说明
v-on:click {set_selected} 点击时将当前项目设置为选中
v-data:focused {index==selected_index} 当前项目选中时高亮

3.8 删除当前选择的采样数据

绑定属性 绑定规则 说明
v-on:click {remove, Args=selected_index} selected_index 表示当前选中的项目

3.9 清除所有采样数据

绑定属性 绑定规则 说明
v-on:click {clear}

3.10 保存采样数据

绑定属性 绑定规则 说明
v-on:click {save}

3.11 重新加载采样数据

绑定属性 绑定规则 说明
v-on:click {reload}

3.12 退出应用程序

绑定属性 绑定规则 说明
v-on:click {nothing, QuitApp=true}

3.12 指定窗口的模型

  • 指定窗口的模型为 history_data

在这里插入图片描述

4. 启用数据采样

修改 design/default/data/settings.json 文件,启用数据采样:

{
   
    "name": "hmi_histroy_data1",
    "history_data": {
   
        "enable": true, /*是否启用数据采集*/
        "fields": {
   
            "time": {
   }, /*时间必须用 'time',放在第一位*/
            "一氧化碳" : {
   
                "min": 0,
                "max": 100,
                "unit": "mg/m³"
            },
            "二氧化氮" : {
   
                "min": 0,
                "max": 110,
                "unit": "mg/m³"
            },
            "悬浮颗粒物" : {
   
                "min": 0,
                "max": 120,
                "unit": "mg/m³"
            },
            "二氧化硫": {
   
                "min": 0,
                "max": 130,
                "unit": "mg/m³"
            }
        },
        "fields_seperator": "|", /*字段之间的分隔符*/
        "max_rows": 1000 /*数据采集最大行数*/,
        "auto_save_interval": 60000
    }
}

5. 编译运行

运行 bin 目录下的 demo 程序。

在这里插入图片描述

6. 使用 MCU 模拟器与之进行交互

运行 mcu/simulator 目录下的 mcu_sim 程序,连接到 Localhost:2233。

  • 通过模拟器发送数据,可以看到串口屏界面,自动添加采样数据。

在这里插入图片描述

测试数据:

1702032398|3.1|3.2|3.3|3.4

7. 注意

  • 本项目并没有编写界面相关的代码,AWStudio 在 src/pages 目录下生成了一些代码框架,这些代码并没有用到,可以删除也可以不用管它,但是不能加入编译。

  • 实际使用时,在 demo_history_data1/design/default/ui/home_page.xml 基础上进行调整即可,无需重复上面的过程,但是最好了解其中的原理。

相关推荐

  1. AWTK 开源串口的配置文件

    2023-12-30 10:30:05       40 阅读
  2. AWTK 开源串口 MODBUS Server 模型

    2023-12-30 10:30:05       182 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-30 10:30:05       91 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-30 10:30:05       97 阅读
  3. 在Django里面运行非项目文件

    2023-12-30 10:30:05       78 阅读
  4. Python语言-面向对象

    2023-12-30 10:30:05       88 阅读

热门阅读

  1. Vue - 事件处理详解

    2023-12-30 10:30:05       55 阅读
  2. Docker搭建kafka集群

    2023-12-30 10:30:05       51 阅读
  3. 如何在Vue.js中使用$emit进行组件通信

    2023-12-30 10:30:05       54 阅读
  4. leetcode贪心(最大子序列和、分发饼干、摆动序列)

    2023-12-30 10:30:05       56 阅读
  5. uboot学习及内核更换_incomplete

    2023-12-30 10:30:05       68 阅读
  6. 【小白专用】c# 如何获取项目的根目录

    2023-12-30 10:30:05       54 阅读
  7. Unity应该如何学

    2023-12-30 10:30:05       54 阅读
  8. uniapp学习之路

    2023-12-30 10:30:05       57 阅读