beam92 发表于 2017-1-13 15:35

雾计算ECE demo开发教程(esp8266试用版)

ECE雾计算esp8266固件包 试用版发布该固件实现了下列功能:

[*]1、当检测到上报温度大于27度时,通知MCU打开电机;
[*]2、当红外对管检测到障碍物时,打开红灯;

本教程配合下载中心的ECE固件开发包使用,结合一个demo教程,教你如何进行ECE开发。
下载地址:ECE雾计算esp8266固件包
ECE入门准备

[*]机智云账号注册
[*]硬件准备
[*]MCU协议介绍
[*]脚本编译及推送

1.机智云账号注册
目前ECE的功能只有注册了机智云的企业账号,在企业账号下的企业产品项目下创建的产品才能体验。
注册教程

注意:需要在企业用户里面创建企业产品才能体验ECE 个人产品目前不支持
http://club.gizwits.com/data/attachment/forum/201701/12/105219kb5b5jhhyy0x5017.png

添加ECE服务:
http://club.gizwits.com/data/attachment/forum/201701/12/105218kzqoy33tt5umrdze.png


http://club.gizwits.com/data/attachment/forum/201701/12/105218n7evqmdvdvgv3f3e.png

http://club.gizwits.com/data/attachment/forum/201701/12/105219e5bxybqxarn22ylq.png

http://club.gizwits.com/data/attachment/forum/201701/12/105439im51in0npe5aakmb.png

等待机智云开通ECE服务

ECE开通后如下图:
http://club.gizwits.com/data/attachment/forum/201701/12/105219lh9dddxfdbheyx4f.png

2.硬件准备
机智云ECE功能现在基于GAgent ESP8266 4M Flash 硬件平台;
第一步我们得找到一个ESP8266的WiFi模组;
第二步拿到机智云提供的支持ECE的固件。
当以上两步准备好,然后进入固件烧录。
烧录教程

2.1设备连接
将ESP8266模块按照如下原理图进行接线,注意GPIO0(18号管脚)需要输入低电平,本实验直接接地处理,KEY1实现外部复位功能
http://club.gizwits.com/data/attachment/forum/201701/12/110245dtlk0lke3mj3fdzz.png

上图为烧录固件简易原理图,在产品中实际搭建线路时,请参考官方提供线路图,如下所示:

http://club.gizwits.com/data/attachment/forum/201701/12/110245kkrqdzkqdkbkkrsf.png

2.2串口设置
将上述串口连接电脑后,通过“我的电脑”->“管理”-> “设备管理器”->“端口(COM 和LPT)”选项中可以看到相应增加的COM口。
http://static.zybuluo.com/AlexLin/sh4ik05qtukepyouh78ltjwc/image_1b3785au5o68b8vj41ath16c513.png
2.3下载烧写软件
下载地址:http://pan.baidu.com/s/1mhMGSeG

下载解压后得到下面文件
http://club.gizwits.com/data/attachment/forum/201701/12/110747fce9djoi59zo452c.png

再次解压图中所示的文件后,双击打开烧写软件,出现如下对话框
http://club.gizwits.com/data/attachment/forum/201701/12/110745jiaqo2v0nn2khon8.png

2.4使用串口烧写方式一烧写固件
拿到支持ECE的ESP8266机智云WiFi固件
请务必依次对照下图所选的地方进行相应的填写:
http://club.gizwits.com/data/attachment/forum/201701/12/111021pjyeq8zf92j93dvu.png

固件烧写操作:
步骤一:当串口连接成功之后,点击如上图的“START”按钮,
http://club.gizwits.com/data/attachment/forum/201701/12/111021pnm7xn0lct06dnza.png

会出现:
http://club.gizwits.com/data/attachment/forum/201701/12/111022r7ptpiek2s8szj81.png

步骤二:将ESP8266进行复位(按下1节原理图所示的KEY1后松开)将会出现如下信息表示模块正在进行烧写。
http://club.gizwits.com/data/attachment/forum/201701/12/111023r3x8tqicwbr3t3sf.png

步骤三:等待一段时间后,出现“FINISH”字样表示烧写成功。
http://club.gizwits.com/data/attachment/forum/201701/12/111023ocn0m0h8ptlffnp0.png

产品初始化信息烧录:
到产品页面找到对应产品的product key,如下图:
http://club.gizwits.com/data/attachment/forum/201701/12/111023o9xqm4hy4sjmhm8s.png

把product key保存到init.lua脚本里面,格式如下:
http://club.gizwits.com/data/attachment/forum/201701/12/111023gfznn7dk1j7af1zr.png

把该文件烧录到0xb0000地址,烧录步骤跟第五部分固件烧写操作一样
http://club.gizwits.com/data/attachment/forum/201701/12/111024u27bbzclf8gc2eqx.png

视频教程:
固件烧录
PK烧录

3.MCU协议介绍
MCU与WIFI通讯以字符串形式通讯,具体命令规范如下:
MCU 通知 WiFi进入airlink配网 cmd=2:
命令:

[*]<font face="微软雅黑" size="3">mcu2wifi&cmd=2&mode=0/1
[*]//解释:
[*]//mode:0 softap配置模式; mode:1 airlink配网模式</font>

复制代码

WIFI回复配网:
命令:

[*]<font face="微软雅黑" size="3">mcu2wifi&cmd=2&result=0/1</font>

复制代码

MCU上传设备数据给WiFi cmd=3:
命令:

[*]<font face="微软雅黑" size="3">mcu2wifi&cmd=3&Infrared=1&LedSwitchOnOff=1&MotorSwitchOnOff=1&Temperature=05</font>

复制代码

WiFi发送控制指令给mcu cmd=4:
命令:

[*]<font face="微软雅黑" size="3">wifi2mcu&cmd=4&LedSwitchOnOff=1或者MotorSwitchOnOff=1</font>

复制代码

实现该协议的固件见机智云下载中心 ECE雾计算esp8266固件包 里面的gokit_mcu_stm32_ece.hex

视频:MCU协议介绍

4.脚本编译及推送
4.1脚本格式及编写规则
请参照demo.lua这个脚本为模板编写自己的lua应用程序,该demo脚本需配套gokit套件及上面提到的模组及MCU固件使用,实现了下列功能:

1.当检测到上报温度大于27度时,通知MCU打开电机;
2.当红外对管检测到障碍物时,打开红灯;

下面我们通过注释区定义了几大块:
应用程序初始化部分,程序请写到luaInit内容区,这部分的代码在整个脚本生命周期只会运行一次,比如分配应用的内存大小,请把lua应用程序需要初始化一次的部分放在这个区域内。


[*]<font face="微软雅黑" size="3">----------luaInit----------
[*]---------内容------------
[*]----------luaInit end----</font>

复制代码

应用程序公有函数部分,程序请写到luaUtils内容区。

[*]<font face="微软雅黑" size="3">----------luaUtils---------
[*]---------内容------------
[*]----------luaUtils end---</font>

复制代码

从app过来的数据处理,程序请写到luaHandleDataFromApp内容区。

[*]<font face="微软雅黑" size="3">----------luaHandleDataFromApp----------
[*]---------------------内容--------------
[*]----------luaHandleDataFromApp end----</font>

复制代码

从MCU设备过来的数据处理,程序请写到luaHandleDataFromApp内容区。

[*]<font face="微软雅黑" size="3">----------luaHandleDataFromDev----------
[*]---------------------内容---------------
[*]----------luaHandleDataFromApp end----</font>

复制代码

注意:由于esp8266资源紧缺,编写的lua应用程序脚本大小不能大于10Kbytes,一次性定义的变量(table\string)不宜超过300个,总变量不宜超过500个。

4.2 lua SDK版本及相关的API
sdk版本:SDK5.1.4

Lua SDK标准库:其中string和table为sdk5.1.4标准库

[*]<font face="微软雅黑" size="3">core,math,C API,auxiliary library</font>

复制代码

不全支持,有裁剪(详细的api请查看文档):gagent_esp8266_api

tmr定时器接口用的是esp8266平台的定时器。
GAgent封装给lua使用的API: 请查看文档:gagent_esp8266_api

4.3 验证lua应用程序的语法
编写好的lua应用程序,可以先用本地的IDE先进行语法编译验证,确保语法编译没有问题,对于调用到的GAgent API,可以先打桩。Window平台推荐LUA本地编译的IDE工具:
SciTE或 LuaForWindows:
http://club.gizwits.com/data/attachment/forum/201701/12/113328rertpta6e7ea8eta.png

Ubuntu安装lua环境:

[*]sudo apt-get install lua、sudo apt-get install lua5.1-0-dev

复制代码

http://club.gizwits.com/data/attachment/forum/201701/12/113329ko3wrw0obpb3r3mm.png

4.4 脚本推送把lua脚本拷贝到lua脚本录入处做推送:
http://club.gizwits.com/data/attachment/forum/201701/12/113329kgf5fscg8qffa2f6.png

可以通过指向mac地址对某台或某几台设备进行脚本推送:
http://club.gizwits.com/data/attachment/forum/201701/12/113329li4o6lmww9kw674o.png

推送结果反馈:
推送成功:

http://club.gizwits.com/data/attachment/forum/201701/12/113329lvmkv51yfkv3r1vy.png

Mac地址出错或设备未上线提示的推送失败:
http://club.gizwits.com/data/attachment/forum/201701/12/113329h7t964a897taa2ha.png

视频讲解:
lua脚本讲解

Gokit跑lua演示
页: [1]
查看完整版本: 雾计算ECE demo开发教程(esp8266试用版)