快速开发一个带APP的红外体温检测枪(基于AliOS Things Inside的Wi-Fi模组)

简介: 非接触红外测温在医疗,环境监测、个人健康等领域得到越来越广泛的应用。本文将向大家介绍如何通过AliOS Things Inside的WiFi模组,快速完成体温检测,流程涵盖从传感器数据采集,到阿里云IoT智能生活平台接入,以及快速构建App完成监控。希望通过阿里云IoT提供的从设备端到云端应用的全套解决方案,快速帮助智能设备厂商,构建出可以替代人力的自动化人体测温设备和方案,在防控中降低人员接触风险,提升排查效率。

1. 简介

非接触红外测温在医疗,环境监测、个人健康等领域得到越来越广泛的应用。本文将向大家介绍如何通过AliOS-Things inside的WiFi模组,快速完成体温检测,流程涵盖从传感器数据采集,到阿里云IoT智能生活平台接入,以及快速构建App完成监控。希望通过阿里云IoT提供的从设备端到云端应用的全套解决方案,快速帮助智能设备厂商,构建出可以替代人力的自动化人体测温设备和方案,在防控中降低人员接触风险,提升排查效率。

2. 软硬件环境

2.1 软件平台

云端     --  阿里云IoT智能生活平台(飞燕平台)
生活物联网平台提供了设备接入能力、移动端的SDK以及免开发的公版App和界面,开发者基于该平台可快速实现设备的智能化。
移动端  -- 云智能(公版App)
云智能是生活物联网平台提供的公版App,无需额外开发,下载后可直接对设备进行配网和控制。支持在全球主流应用商店中搜索“云智能”下载;
设备端  -- AliOS Things 3.0.0版本
AliOS Things作为轻量级物联网OS,已支持多款芯片,可以方便的集成温度传感器,并通过设备端SDK连接生活物联网平台;这里选用其最新发布的3.0.0版本。

2.2 硬件平台

硬件平台
硬件平台选用ESP8266 nodeMCU,支持Wifi连接,带有I2C、UART等接口,并且带有按键(FLASH按键),可用于触发体温检测上报。
image.png
传感器--MLX90614ESF-DCI-000-TU(I2C接口)
这颗传感器是一款红外的非接触温度计,支持I2C通信协议,主要用到SDA和SCL两条线,可以很方便的连接到ESP8266开发板上。
image.png
说明如下:
image.png
硬件连接
开发板与传感器的接线引脚对应关系如下:

开发板 传感器
D1 (GPIO_05) SCL
D2 (GPIO_04)
SDA
3.3V Vcc
GND GND

image.png

硬件连接图,右键可打开大图

3. 云端配置

智能生活平台上创建产品及设备之前,请先确保以下两点:

3.1 产品创建

在控制台上已创建项目、产品,并完成产品的功能定义,可参见概述完成这部分的操作。功能定义时,需要注意以下两点:

  1. 产品类型选择“体温计”, 标准功能中已经包含了“人体温度”,这里只需要修改数据定义中的取值范围为0~99。
    image.png
  2. 如上图所示,设备端上报温度使用的标识符,需要与云端的配置保持一致(如上图“人体温度”所对应的标识符);

3.2 测试设备添加

添加测试设备,记录设备的激活凭证(ProductKey、ProductSecret、DeviceName、DeviceSecret,如下图红框处),后续需要将激活凭证配置到设备端。
image.png

3.3 App配置使用

公版App的参数配置及流程如下所示:

  1. 打开公版App的控制开关,详细参见配置App交付终端
  2. 设置App参数,其中选择产品面板多语言管理配网引导为必填参数,详细请参见设置App参数
  3. 下载公版App(云智能),具体参考公版App介绍
  4. 扫描配网二维码,绑定设备后调试,具体二维码参见获取配网二维码

4. 代码移植

获取参考代码(如图所示),并按以下步骤集成。
image.png

4.1 ESP8266单板适配

针对上述选用的ESP8266开发板,为保证按键中断、I2C等功能正常运行,需要做以下修改:

  1. FLASH按键对应的GPIO引脚修改;
  2. I2C总线对应的引脚修改;
  3. 8266不支持C99编译的适配;

具体修改可参考附件中的补丁文件(001-aos-3-0-0-esp8266.patch,基于AliOS Things 3.0.0版本生成)。将其拷贝到AliOS Things 3.0.0根目录下,通过以下命令打入补丁:

patch -p1 < ./001-aos-3-0-0-esp8266.patch

4.2 驱动移植

MLX90614是一款用于非接触式温度测量的红外温度计,这里主要介绍其使用方法。MLX90614的EEPROM主要用来做参数配置,具体可参考官方手册:
image.png
MLX90614的RAM为只读属性,用户可以读取温度等数据,例如,通过RAM上的Tobj1可以获取被检测物体的温度数据。
image.png
I2C总线通过设备地址0X5A(MLX90614出厂设置)来访问传感器。访问RAM和EEPROM时,操作命令的对应关系如下所示:
image.png

例如访问EEPROM上0X4的地址(Emissivity correction coefficient ),其操作可以通过以下方式得到:

  1. 访问的是EEPROM,其操作码高3位为0b001
  2. 后5位为访问的地址,该地址为0X4,二进制表示为0b00100
  3. 按照上图的方式组合,操作命令为 0b00100100,即0X24

按照同样的方式,通过RAM读取被测物体温度寄存器(Tobj1)数据的操作码为0X7。
被测物体温度读取的驱动代码(位于drv_temp_melexis_mlx90614.c 中)参考如下:

static int drv_temp_melexis_mlx90614_read(void *buf, size_t len)
{
    int                 ret = 0;
    size_t              size;
    uint8_t             data[2];
    int32_t             temp;
    uint32_t            value;
    temperature_data_t *pdata = (temperature_data_t *)buf;
    if (buf == NULL) {
        return -1;
    }

    size = sizeof(temperature_data_t);
    if (len < size) {
        return -1;
    }

    /* 通过I2C读取RAM上的Tobj寄存器 
         MLX90614_ctx.config.dev_addr为设备地址0X5A
       MLX90614_TOBJ1为访问Tobj1的操作码0X07 */
    ret = hal_i2c_mem_read(&MLX90614_ctx, MLX90614_ctx.config.dev_addr, MLX90614_TOBJ1, I2C_REG_LEN, data,
                           2, I2C_OP_RETRIES);
    value = data[0] | (data[1]<<8);
    if (unlikely(ret)) {
        return -1;
    }
    /* 寄存器的值转换成温度数据,单位为0.01℃ */
    temp = ((int32_t)value * 2) - 27315;
    pdata->t = temp;
    pdata->timestamp = aos_now_ms();

    return (int)size;
}

下面介绍如何集成驱动,将驱动文件drv_temp_melexis_mlx90614.c拷贝到driverssensordrv目录下,并且在driverssensordrv.mk的第一行添加编译配置。

    ifeq ($(AOS_SENSOR_TEMP_MELEXIS_MLX90614),y)
    $(NAME)_SOURCES += drv/drv_temp_melexis_mlx90614.c
    endif

4.3 用例移植

将用例代码(thermometer文件夹)拷贝到appexample目录下,并且在appexampleConfig.in中添加用例编译配置。

source "app/example/thermometer/Config.in"
if AOS_APP_THERMOMETER
    config AOS_BUILD_APP
        default "thermometer"
endif

用例初始化流程如下所示,具体请参考入口函数application_start:
image.png
ESP8266的按键中断相关代码在mcuesp8266bspkey.c中,按下按键后,中断回调函数会根据按键按下的时间(短按、2秒钟长按、6秒钟长按),触发不同的event(通过aos_post_event)。application_start中注册的按键回调,会响应上述事件,按键回调代码如下:

/* 按键回调函数 */
void linkkit_key_process(input_event_t *eventinfo, void *priv_data)
{
    if (eventinfo->type != EV_KEY) {
        return;
    }

    if (eventinfo->code == CODE_BOOT) {
        if (eventinfo->value == VALUE_KEY_CLICK) {
            /* 短按(>40ms),触发一次体温检测,并上报云端 */
            app_sensor_test();
        } else if (eventinfo->value == VALUE_KEY_LTCLICK) {
            /* 长按(>2s), 触发系统进入配网模式 */
            do_awss_active();
        } else if (eventinfo->value == VALUE_KEY_LLTCLICK) {
            /* 长按(>6s),会清除配网信息,并复位系统 */
            do_awss_reset();
        }
    }
}

体温数据检测、上报流程请参考相关代码,检测低于正常人体温度范围(34~42℃),则上报数据0,高于正常人体温度范围,则上报数据99:

/* 读取温度数据并上报云端 */
void app_sensor_test()
{
    int ret;
    char param[128];
    temperature_data_t temp;
    double data = 0.0;

    /* 读取温度传感器数据 */
    ret = sensor_hal_read(TAG_DEV_TEMP, 0, &temp, sizeof(temp));
    if(ret <= 0){
        printf("\nSensor data read fail \n");
        return;
    }

    data = (double)temp.t;
    data = data/100.0;

    /* 人体温度数据校准 */
    data = data - (data * data * data *data * data* data) * 0.000125 +
           (data * data * data *data * data) * 0.0283429488 -
           (data * data * data *data ) * 2.67004808 +
           (data * data * data ) * 133.762569 -
           (data * data ) * 3758.41829 +
           (data ) * 56155.4892 -
           348548.755;

    if (data < 34.0) {
        data = 0.0;
        printf("\nNot the normal range of human body temperature (34 ~ 42℃ ) \n");
    }
    else if (data > 42.0) {
        data = 99.0;
        printf("\nNot the normal range of human body temperature (34 ~ 42℃ ) \n");
    }
    
    /* 网络连接检测 */
    if (!app_conect_check()) {
        printf("\nNetwork is not connected\n");
        return;
    }

    memset(param, 0, 128);

    /* 构建上报云端的payload */
    sprintf(param, PROP_POST_FORMAT_TEMP, data);

    /* 上报体温数据到云端 */
    if (app_init_check() != 0) {
        ret = IOT_Linkkit_Report(app_device_get(), ITM_MSG_POST_PROPERTY, (unsigned char *)param, strlen(param) + 1);
        if (ret == -1) {
            LOG("%s %d fail\n", __func__,__LINE__);
        }
    }
}

4.4 四元组修改

将3.2节中记录的设备的激活凭证(四元组)更新到设备端(appexamplethermometer目录下的app_entry.h中):

#define PRODUCT_KEY    "xxxxxxxxxxx"
#define PRODUCT_SECRET "xxxxxxxxxxxxxxxx"
#define DEVICE_NAME    "xxxxxxxxxxxxxx"
#define DEVICE_SECRET  "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"

4.5 标识符确认

参考3.1节,确保设备端上报体温对应的功能标识符(appexamplethermometer目录下的app_entry.h中)与云端的配置一致:

#define PROP_POST_FORMAT_TEMP "{\"BodyTemperature\":%.1f}"

5. 编译运行

5.1 编译

  1. 在OS目录下执行以下命令,完成编译
  2. make thermometer@esp8266  -c config

aos make

  1. 编译生成的固件thermometer@esp8266.bin在outthermometer@esp8266binary目录下
  2. 通过ESP8266的Flash下载工具(FLASH_DOWNLOAD_TOOLS)烧录

5.2 运行

开发板参考如下:
image.png
复位单板后,长按"FLASH"键(>2s),开启配网流程,APP端参考官方文档中的“公版App使用流程”完成。
配网成功后,短按"FLASH"键(>40ms),可以触发一次温度采集,并上传云端,同时推送到手机侧云智能APP。
image.png

需要注意的是,用例中增加了校准,检测温度的的范围是34 ~ 42℃,低于这个范围,上报数据为0;高于这个范围,上报数据为99。

6. 附录

问题交流、技术支持群:
image.png

相关实践学习
钉钉群中如何接收IoT温控器数据告警通知
本实验主要介绍如何将温控器设备以MQTT协议接入IoT物联网平台,通过云产品流转到函数计算FC,调用钉钉群机器人API,实时推送温湿度消息到钉钉群。
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
相关文章
|
4天前
|
前端开发 Java 开发工具
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
|
4天前
|
Dart 前端开发 Android开发
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
5天前
|
Dart 前端开发 架构师
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
|
21天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
167 18
|
17天前
|
JSON 供应链 搜索推荐
淘宝APP分类API接口:开发、运用与收益全解析
淘宝APP作为国内领先的购物平台,拥有丰富的商品资源和庞大的用户群体。分类API接口是实现商品分类管理、查询及个性化推荐的关键工具。通过开发和使用该接口,商家可以构建分类树、进行商品查询与搜索、提供个性化推荐,从而提高销售额、增加商品曝光、提升用户体验并降低运营成本。此外,它还能帮助拓展业务范围,满足用户的多样化需求,推动电商业务的发展和创新。
44 5
|
17天前
|
移动开发 安全 搜索推荐
圈子社交系统APP,同城本地圈子论坛开发,让身边的人沟通更加紧密
圈子社交系统APP是一款基于社交网络的移动应用,用户可创建、加入和管理兴趣圈子。主要功能包括:动态分享与交流、实时聊天、会员体系与身份认证、活动策划等。该APP注重个性化定制、社交关系深化、隐私安全及跨平台互联,提供丰富的社交体验。
|
20天前
鸿蒙语言开发 几十套鸿蒙ArkTs app毕业设计及课程作业
鸿蒙语言开发 几十套鸿蒙ArkTs app毕业设计及课程作业
28 1
|
29天前
|
JSON 缓存 前端开发
HarmonyOS NEXT 5.0鸿蒙开发一套影院APP(附带源码)
本项目基于HarmonyOS NEXT 5.0开发了一款影院应用程序,主要实现了电影和影院信息的展示功能。应用包括首页、电影列表、影院列表等模块。首页包含轮播图与正在热映及即将上映的电影切换显示;电影列表模块通过API获取电影数据并以网格形式展示,用户可以查看电影详情;影院列表则允许用户选择城市后查看对应影院信息,并支持城市选择弹窗。此外,项目中还集成了Axios用于网络请求,并进行了二次封装以简化接口调用流程,同时添加了请求和响应拦截器来处理通用逻辑。整体代码结构清晰,使用了组件化开发方式,便于维护和扩展。 该简介概括了提供的内容,但请注意实际开发中还需考虑UI优化、性能提升等方面的工作。
93 11
|
26天前
|
前端开发 数据库 UED
uniapp开发,前后端分离的陪玩系统优势,陪玩app功能特点,线上聊天线下陪玩,只要4800
前后端分离的陪玩系统将前端(用户界面)和后端(服务器逻辑)分开开发,前者负责页面渲染与用户交互,后者处理数据并提供接口。该架构提高开发效率、优化用户体验、增强可扩展性和稳定性,降低维护成本,提升安全性。玩家可发布陪玩需求,陪玩人员发布服务信息,支持在线聊天、预约及线下陪玩功能,满足多样化需求。[演示链接](https://www.51duoke.cn/games/?id=7)
|
1天前
|
移动开发 小程序
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
5 0