signed

QiShunwang

“诚信为本、客户至上”

5-STM32+BC26/260Y基本控制篇(自建物联网平台)-整体运行测试-微信小程序扫码绑定BC260Y,并通过MQTT和BC260Y实现远程通信控制

2021/3/21 10:27:27   来源:

 

 

说明

这节测试一下微信小程序扫码绑定BC260Y模组然后实现微信小程序和开发板之间通过MQTT进行远程通信控制.

这一节作为板子的整体功能测试,用户下载这一节的程序用来测试基本控制篇实现的基本功能

还有就是测试一下板子是否工作正常.

先睹为快

 

测试准备工作

1.请根据硬件使用说明下载这节程序到单片机

 

 

 

 

2.单片机工程目录

 

 

3.Hex文件位置

 

 

 

 

4.别忘了安装好手机卡和天线

 

5.安装微信小程序(使用开发工具打开以下工程)

注:如果没有学习过小程序,请先学习微信小程序开源教程

 

 

 

6.点击 预览,使用微信扫码以后安装到手机

注:默认连接的我的服务器,mnif.cn,用户可以在详情里面选择不校验域名(不推荐,可能通信有问题)

 

 

 

也可以在微信小程序平台上设置域名白名单(推荐)

 

 

 

 

 

 

 

注:预览模式有时间限制,如想长期使用,请发布小程序

 

 

7.添加设备

 

 

 

8.选择扫码添加

 

 

 

9.扫描模组上面的二维码

注:双击下屏幕可以放大摄像头扫描倍数

 

 

 

 

10.扫描成功以后将会在主页面添加一个设备

注:显示的内容为模组的IMEI号

 

 

 

11.点击显示的设备,进入设备控制页面

 

 

 

测试继电器控制

1.点击中间的开关控制继电器

 

 

 

 

 

 

2.动作一下开发板上面的 PB5按键,继电器会翻转

 

测试温湿度传感器

1.正常情况下OLED会显示当前的温湿度数据(也可以验证OLED是否工作正常)

 

注:可以给温湿度吹吹气,改变一下温湿度.

 

 

测试光敏电阻

注:这个不是真的光照强度!我只是采集了电压,然后乘了数然后显示而已!

 

 

 

可以用手盖住传感器看下采集的数是否变化.

 

测试RGB

用手拖动,可以看到板子上的灯随着拖动颜色的变化而变化

 

 

测试485

1.使用USB转485模块连接开发板

 

 

 

2.给485所在的串口号发送信息,将会收到同样的信息

 

 

测试CAN总线

程序写了一个回环测试,可以在日志上面看到CAN测试结果

 

 

提示

后面是介绍整个程序,如果是初学者大概看一下就可以.

写后面的目的是给已经有基础的了解一下整个程序执行步骤.

便于迅速的实际应用到项目中.

对于初学者按部就班的一节一节的学习就可以.

后面的教程会一步一步的让用户知道所有的一切是怎么做到的.

 

程序整体说明

1.提示

整个程序就是利用MQTT服务器实现APP和设备之间通信.

设备连接上MQTT以后

订阅的主题是: user/设备的IMEI  发布的主题: device/设备的IMEI

 

APP扫码得到设备的IMEI

发布的主题是: user/设备的IMEI  订阅的主题是: device/设备的IMEI

 

协议规定:

 

 

 

 

3.单片机程序

 

 

 

①:控制模块连接TCP服务器(MQTT服务器)

②:MQTT消息处理封装包(缓存管理,支持消息等级0,1,2)

 

4.微信小程序

 

 

① 添加设备页面
② 控制页面
③ paho-mqtt.js 官方底层包  mqtt.js本人再次封装的mqtt包

 

单片机程序详细说明

如果是初学者,可以先学习后面章节的基础知识.学完基础知识以后再来看测试代码的执行步骤.

1.关于串口1

串口1作为日志打印,发送数据采用中断+环形队列,

 

 

 在串口2和串口3发送数据的地方把相应数据发给串口1打印出来.

 

 

 

串口2和串口3接收的数据使用串口1打印出来.

 

 

 

 

 

 

2.关于串口2

串口2和模组通信.

串口2接收的数据存储有两个方向,一个是存储到usart2_read_buff 数组,另一个是存储到环形队列

环形队列只存储模组过来的网络数据!使用环形队列有利于把全部的网络数据缓存住.

 

 

 

提示:模组接收的网络数据数这样子的,所以上面有个解析组合程序

 

 

2.注册MQTT相关函数

 

 

3.配置模组连接MQTT时,主循环在这里把接收的数据传递给配置函数

 

 

 

4.配置模组连接MQTT服务器

 

 

 

5.发送MQTT连接指令

提示:先前获取的IMEI就存储在 MQTTid这个数组里面.

所以下面组合的发布主题为:device/设备的IMEI

 

 

注:发送的消息需要转成16进制表达的字符串

 

 

 

 

6.连接成功调用注册的连接回调函数(在回调函数里面发送订阅主题的协议)

 

 

 

提示:先前获取的IMEI就存储在 MQTTid这个数组里面.

所以下面组合的订阅主题为:user/设备的IMEI

 

 

 

7.在注册的接收回调函数中处理接收的消息

 

 

 

 

 

 

8.发布消息

如果继电器状态改变,上报继电器状态

每隔5S发送传感器数据给APP

 

 

 

9.细节说明-关于串口2接收数据的配置

串口2判断空闲使用的定时器,原因是GSM串口发送的数据并不是那么的标准,中间有断断续续的情况.

用自带的空闲中断检测会把一条数据判断成多条.所以用定时器加长了空闲时间判断.

 

 

 

 

 

10.细节说明-实际发送MQTT数据的地方

注:用户发送数据是使用 mqtt_publish(&mymqtt,MQTTPublishTopic,MainBuffer,MainLen, 0, 1,PublishedCb);

调用这个函数是把数据放到缓存里面,实际是在下面的函数里面发送出去

 

 

 

 

  

10.细节说明-RGB控制的参数会实时记录在Flash里面

注:存储方式采用我封装的 flash_helper. 每次启动会直接显示以前的灯的状态.

 

 

使用flash_helper使得flash的擦写寿命为100万次,基本上不用担心寿命问题.所以把每次数据都存储到flash

 

 

微信小程序程序详细说明

1.mqtt.js 是封装的MQTT相关的函数

 

 

 

2.点击添加设备

 

 

 

3.点击扫码绑定,并把扫描的二维码信息传递到主页

 

 

 

4.BC26的二维码信息是  IMEI号;SN码  需要只提取IMEI 然后存储到数据库,并更新

 

 

 

5.点击某一个设备,携带着这个设备的IMEI号跳转到控制页面

 

 

 

6.控制页面获取数据

 

 

 

 

7.订阅主题,和轮训查询设备数据

 

 

 

 

 

 

 

 

 

 

 

8.接收处理消息

 

 

 

 

 

 

 

9.发布消息

 

 

 

 

 

其它

 

 

当前只用到了红色的RGB自定义组件 

circle_progress 暂时没有用,因为存在问题

蓝色是使用 npm安装的lin-ui,也没有使用.

 

结语

对于初学者,感受一下远程通信就可以.在后面的章节中将会详细的学习到是怎么做到的.