同步操作将从 miuser/midemo 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
[TOC]
版本 V0.3
midemo 计划用一组极简单的AT增强指令,简化现有的物联网模块联网方式,并增强现有物联网模块对外设的控制能力。 具体功能如下:
一、内置upws开源网络通讯组件,可以通过手机扫描二维码直接与模块建立通讯,收发指令
二、使用LED(极简)或 SSD1306单色点阵显示屏(推荐)展示系统运行状态
三、支持外挂320X240分辨率以下的SPI全彩显示屏和扬声器进行文字信息输出
四、支持指令控制实时外挂各种总线设备,包括传感器,执行器等,兼容SPI、UART、MODBUS等总线方式
五、支持定时指令控制
六、支持多链路连接并自动维护网络持续可用,目前支持三路同时在线,1、upws(默认内置),2、标准MQTT,3、阿里云透传
七、支持远程恢复和固件升级
Midemo适用于合宙出品全系列Cat1模块,支持该模块的核心板,开发板,以及各类定制产品。代码通过Luatools烧写
推荐使用开源电话核心板Cat1 Phone Core 作为硬件平台,项目地址:https://www.oshwhub.com/miuser/elderphonev2-schdoc 成品核心板也已经面世。欢迎购买!稳定、开源,量大价格从优,购买地址: https://item.taobao.com/item.htm?id=624610770134
一、连接USB端口,安装好驱动程序,然后使用LuatoolsV2 将项目源码(midemo目录及子目录)全部烧写到目标的核心板。(商品板自带,不需要另外烧了)
二、运行二维码生成程序 M2MReader.exe,生成遥控二维码并通过手机扫码控制(商品板自带二维码标签,不需要自己打)
三、使用MiCOM发送MAT指令(名称为:LUAT USB Device 1 AT COMXX),实现相应功能
合宙Cat1 USB驱动、LuatoolsV2,串口工具,底包,脚本
https://file.miuser.net/?dir=/Luat/basic
一、安装驱动和LuattoolsV2,并完成自动在线更新
二、选择合宙底包,并烧写midemo开源代码,步骤如下
运行LuatoolsV2,并选择项目管理测试
新建项目
选择底包和脚本
连接USB线并烧写
上电后,有三种方式可以控制模块。 推荐前两种方式!
1,通过手机扫描使用工具生产的二维码。
2,使用本地USB虚拟AT串口访问模块。
3使用附带的C#demo通过UDP方式访问模块。
本DEMO采用标准的AT方式进行通讯。
举例:
SETGPIO,13,1 -> 设置GPIO13位高电平
SETGPIO,13,1->OK <- midemo回送通讯正常
GPIOLEVEL,13,1 <- midemo回送当前GPIO13电平状态为高
GPIOEDGE,13,1 <- midemo回送GPIO13上升沿触发状态
三、更详细的Luat开发步骤,请参考合宙官网doc系统,有详细介绍
https://doc.openluat.com/wiki/3
midemo的一切功能均通过指令和消息完成,指令被称为MAT,消息被称为MATR
MAT 指令 --指用户发送给midemo的指令,全称为 Miniums Attention
MATR 消息--指midemo发送给用户的消息,全称为 Minimus Attention Respond
MAT和MATR采用GB2312编码,且均可以携带任意个参数,参数之间采用英文字符逗号"," 分隔,在参数和命令中逗号为保留字符禁止使用,如果确有需要,以中文逗号代替,中文逗号则用两个连续的中文逗号代替。
midemo基于上海合宙luatask架构编写,使用iRTU开源物联网固件作为通讯内核,各个模块采用协作式多任务(协程)方式进行通讯。 模块拥有全球唯一的ID识别码,和唯一的MM通讯密码。 ID+MM方式实现双向收发鉴权,仅ID方式适用于单向侦听网络包,但无权发送。 ID和MM可以通过二维码生成器生成,并将在模块上电时从串口打印输出。
<dir> CS_UDP_demo --C#编写的模块控制程序demo,支持通过本地串口和网络UDP方式访问upws接口控制模块
<dir> page --html5编写的模块控制页面,跨平台支持PC、手机、平板上的各种浏览器、微信扫一扫等
main.lua --入口文件
bs.lua --midemo模块配置文件
<dir> LICENSE --版权信息
<dir> iRTU --网络通讯组件包
<dir> midemo_core --项目核心文件
<dir> midemo_ext --第三方编写的模块(含样例)
<dir> midemo_media --项目媒体,如声音图片等
<dir> 外标签打印程序 --外标签二维码打印程序
<dir> Module_Printer--模块访问二维码打印程序
您可以参考midemo_ext目录提供的demo.lua构建您的传感器或者执行器控制代码。 只需遵循一些基本原则,您的代码就可以与midemo框架共享本地硬件资源和网络接口,而不至发生干涉。
--------------------------------------------------------------------
-- -
-- 三方模块加载表 -
-- -
--------------------------------------------------------------------
--外部模块DEMO
require "XXX" --此处是您需要添加的代码
require "demo"
第一步:通过sys.subscribe响应您要设立的AT指令,本例中指令名为为DOWORK
--通过这个回调函数可以响应任意的串口或网络发布的命令
sys.subscribe("DOWORK",function(...)
--通过arg可以从输入的命令行读入参数,并以逗号作为分隔符
--a=arg[1]
--b=arg[2]
--c=arg[3]
--通过write函数可以向串口和网络上报您的信息
write("您刚刚执行了DWORK命令,".."命令共有"..#arg.."个参数".."\r\n")
end)
第二步:通过调用write函数,向本地COM口和网络接口发送指令执行后的回送信息
--通过消息发送调试信息到串口和网络客户端
function write(s)
--log.info("testUartTask.write",s)
sys.publish("COM",s)
sys.publish("NET_CMD_MONI",s)
end
COM --向AT串口发送字符串消息
NET_CMD_MONI --向网络接口发送字符串消息
DISPLAY --向OLED显示屏投送一行字符串
在进行模块编写时,建议遵循以下的原则。
midemo.bs是系统的全局配置文件,先于其他功能模块加载。提供了其他功能模块初始化的基本参数。参数分为强制配置部分和可选配置部分。
模块 | 全称 | 功能 |
---|---|---|
com | com模块 | 命令通讯串口消息收发的基础模块 |
irtu_init | iRTU固件执行前适配 | 适配iRTU通讯内核(初始化) |
default | iRTU通讯内核 | iRTU通讯内核 (执行) |
irtu_over | iRTU固件执行后清理资源占用 | 适配iRTU通讯内核(清理) |
upws | upws模块 | 负责和upws服务器进行通讯 |
maliyun | 阿里云模块 | 负责和阿里云服务器进行通讯,采用自注册方式,其中三元组信息可以在midemo.bs中修改 |
mmqtt | 标准MQTT模块 | 负责通过匿名方式连接MQTT服务器,服务器地址为box.miuser.net,端口为TCP 1883,可以在midemo.bs中修改 |
oled | oled模块 | 显示网络的连接质量,CPU占用情况与控制台输入的指令 |
gpo | gpo模块 | 强制设置GPIO的电平状态,GPIO在midemo.bs中设置 |
bio | bio模块 | 设置或者查询GPIO的电平状态,GPIO在midemo.bs中设置,默认为GPIO13 |
btn | btn模块 | 将GPIO映射为一个按钮,需要映射的GPIO在miuser.bs中设置,默认是GPIO19 |
cmd | cmd模块 | 常用内部命令,包括查询ID、MM、SN、IMEI等 |
mkey | mkey模块 | 功能:配置开机键的功能 |
onedial | onedial模块 | LTE语音通话 |
ttsplus | ttsplus模块 | 文本朗读,在官方库基础上增加了几个符号的朗读 |
trsms | trsms模块 | 短信收发 |
mgps | GPS定位模块 | 通过外部连接Air530GPS模块实现GPS定位,GPS端口号和波特率可以在midemo.bs中设置,默认为COM1 |
help | help模块 | 在线帮助系统,输入help可以查看所有模块的详细使用方法 |
功能名 | 全称 | 功能 |
---|---|---|
ws2812bmatrix | ws2812bmatrix模块 | 8X8方形ws2812b全彩LED阵列驱动模块 |
gc9a01 | gc0a01模块 | 驱动240X240分辨率的gc0a01圆形显示屏幕 |
hyperstepper | Hyperstepper步进电机驱动模块 | 驱动Hyperstepper开源闭环步进电机进行交度旋转 |
st7735 | st7735模块 | 驱动160X128分辨率的st7735显示屏幕 |
demo | demo样例 | 本DEMO是一个框架程序描述如何向DEMO集添加您自己的模块 |
通过在 midemo 的"LOAD_MODULE"表中添加对应的模块既可以实现相应的功能。 对应的指令在MAT指令集中进行介绍
midemo.bs作为全局配置文件,配置优先级高于子模块,在本文件中配置的参数将覆盖子模块的缺省设置。所有支持的可选设置都以注释的形式存在,将相应的注释移除即可仿照原格式进行编辑配置
--UPWS连接 CHANNEL=1
--UPWS服务器
UPWS_SERVER="box.miuser.net"
--UPWS UDP端口
UPWS_PORT=7101
--MQTT服务 CHANNEL=2
--MQTT服务器
MQTT_SERVER="box.miuser.net"
--MQTT TCP 端口
MQTT_PORT=1883
--使用MQTT.fx调试时调试软件上主题的末尾不加"/",但此处应该加上
--设备订阅的主题
MQTT_subTopic="/server/"
--设备发布的主题
MQTT_pubTopic="/device/"
--阿里云服务 CHANNEL=3
--服务器Region
RegionID="cn-shanghai"
--产品ProductKey
ProductKey="a18AEOym3ET"
--项目AccessKey
AccessKey="LTAI4GBhk4Wb2C71wwjgtcve"
--项目AccessKeySecret
AccessKeySecret="IrVCeGi9hXnQCNIeNUr0HRBrGuSBfV"
--设备订阅的主题
ALIYUN_subTopic="/sys/a18AEOym3ET/${deviceName}/thing/service/property/set"
--设备发布的主题
ALIYUN_pubTopic="/sys/a18AEOym3ET/${deviceName}/thing/event/property/post"
--命令控制台映射模式 0,不映射 1,直接映射 2,映射为路由模式
--MQTT映射为控制台的接口
MTCP_OVER_MQTT=2
--阿里云映射为控制台的接口
MTCP_OVER_ALIYUN=2
--将USB虚拟串口分配作为命令控制接口
COM_UART_IDs={129}
--MQTT映射到的硬件串口号
MQTT_COM={1}
--阿里云映射到的硬件串口号
ALIYUN_COM={2}
--GPIO13映射为双向IO端口
BIOPins={13}
--GPIOX为输出IO端口
OUTPins={20,21}
--GPS功能使用的COM口号
GPSCOM=1
GPSBaudRate=9600
--按钮功能,需要使用空白的GPIO口
BTNPins={19,18}
--将GPIOX作为来电指示,nil为无来电指示灯
PHONELED=nil
--VLCD电压为3.2V
VLCD=16
--VMMC电压为1.8V
VMMC=2
-- PMD=0时:关闭LDO
-- PMD=1时:LDO输出1.7V
-- PMD=2时:LDO输出1.8V
-- PMD=3时:LDO输出1.9V
-- PMD=4时:LDO输出2.0V
-- PMD=5时:LDO输出2.2V
-- PMD=6时:LDO输出2.3V
-- PMD=7时:LDO输出2.4V
-- PMD=8时:LDO输出2.5V
-- PMD=9时:LDO输出2.6V
-- PMD=10时:LDO输出2.7V
-- PMD=11时:LDO输出2.8V
-- PMD=12时:LDO输出2.9V
-- PMD=13时:LDO输出3.0V
-- PMD=14时:LDO输出3.1V
-- PMD=15时:LDO输出3.2V
作用:负责和upws服务器进行通讯 upws服务器采用内置的服务器,默认地址为box.miuser.net UDP: 7101,也可以在midemo.bs中修改 该模块使用iRTU固件的通道1进行通讯,心跳包间隔为10S 心跳包是一个JSON格式的字符串,包含了模块当前的运行状态 发送网络消息采用 NET_CMD_MONI消息、例如:sys.publish("NET_CMD_MONI",str) str是网络上行的字符串消息 接收网络消息采用 NET_CMD_MINO消息、通过:sys.subscribe("NET_CMD_MINO", function(str) ... end) 可以收到服务器下行的字符串消息
负责和阿里云服务器进行通讯,采用自注册方式,其中三元组信息可以在midemo.bs中修改 该模块使用iRTU固件的通道3进行通讯,心跳包间隔为10S 心跳包是一个字符串,内容为"ALIYUN HEART BEAT" 共用三种用法 1、可以在midemo.bs将任一空闲串口映射为阿里云的透传端口 配置ALIYUN_COM为某个闲置的串口(闲置指的是未被控制台使用),配置MTCP_OVER_ALIYUN=3 2、可以在midemo.bs将命令通讯接口映射为阿里云的透传端口配置 配置ALIYUN_COM为{},配置 MTCP_OVER_ALIYUN==1 3、可以在midemo.bs将命令通讯接口配置为阿里云的路由端口 配置ALIYUN_COM为{},配置 MTCP_OVER_ALIYUN==2 在第3种方式下 通过发布名为"ALIYUN_SEND"的系统消息发送数据到阿里云服务器 通过订阅名为“ALIYUN_RECEIVE”的系统消息接收阿里云服务器下发的数据
作用:负责通过匿名方式连接MQTT服务器,服务器地址为box.miuser.net,端口为TCP:1883,可以在midemo.bs中修改 该模块使用iRTU固件的通道2进行通讯,心跳包间隔为10S 心跳包是一个字符串,内容为"MQTT HEART BEAT" 共用三种用法 1、可以在midemo.bs将任一空闲串口映射为MQTT服务器的透传端口 配置MQTT_COM为某个闲置的串口(闲置指的是未被控制台使用),配置MTCP_OVER_MQTT=3 2、可以在midemo.bs将命令通讯接口映射为MQTT服务器的透传端口配置 配置MQTT_COM为{},配置 MTCP_OVER_MQTT==1 3、可以在midemo.bs将命令通讯接口配置为MQTT服务器的路由端口 配置MQTT_COM为{},配置 MTCP_OVER_MQTT==2 在第3种方式下 通过订阅名为“MQTT_RECEIVE”的系统消息接收MQTT服务器下发的数据 通过发布名为“MQTT_SEND"的系统消息发送数据到MQTT服务器
功能:显示网络的连接质量,CPU占用情况与控制台输入的指令 当控制台收到DISPLAY的消息,则在屏幕第四行显示。比如消息为 DISPLAY,CMD,XXXX 则OLED将显示如下内容 ************************ ** CPU: 60% RAM: 80% ** ** CSQ: 18 NET:UMA ** ** ** ** CMD,XXXXX ** ************************ 网络连接状态U代表UPWS服务器,M代表MQTT服务器,A代表阿里云服务器,对应的网络连接成功,则对应的字符会显示出来 仅支持英文字符集,中文字符将以**替代
功能:强制设置GPIO的电平状态,GPIO在midemo.bs中设置
例子: SETGPO,18,1 GPIO18引脚被设置为高电平 当对应的端口设置为GPO端口时,会上报当前设置的电平 GPIO_LEVEL,GPO,0/1的提示 (GPO,为设置的电平的GPIO口,0为下降沿,1为上升沿)
功能:设置或者查询GPIO的电平状态,GPIO在midemo.bs中设置,默认为GPIO13
GETGPIO,pio 获取对应的GPIO的真实外部电平 例子: SETGPIO,18,1 GPIO18引脚被设置为弱高电平
当对应的端口设置为GPIO端口时,还会自主上报电平发生变化的信息 GPIOEDGE,0/1的提示 (0为下降沿,1为上升沿) GPIO_LEVEL_CHANGE,0/1的提示 (0为低电平,1为高电平)
功能:将GPIO映射为一个按钮,需要映射的GPIO在miuser.bs中设置,默认是GPIO19 使用方法 按钮连接到对应的IO口和1.8V之间
功能:常用内部命令,包括查询ID、MM、SN、IMEI等
例子: GETID 系统返回ID=1234567890,ID为10位数字构成的模块识别码,每个模块此项都不相同 GETMM 系统返回ID=1234567890ABCDEF,ID为16位字符构成的模块密码,每个模块此项都不相同 GETIMEI 系统返回ID=1234567890ABCDE,IMEI为15数字构成的IMEI号,每个模块此项都不相同 GETSN 系统返回ID=1234567890ABCD,SN为14数字构成的模块出厂序列号,每个模块此项都不相同 GETICCID 系统返回ICCID=12345678901234567890,ICCID为20位数字构成的SIM卡识别码,这个值存在物联网SIM卡
功能:配置开机键的功能 使用方法 按钮连接到POWERKEY和GND
功能:LTE语音通话
当外部电话呼入,控制台会显示[onedial]INCOMING CALL,13XXXXXXXXX的消息, 13X..为呼入号码 当呼出电话时,控制台会显示[onedial]DIALING,13XXXXXXXXX的消息, 13X..为呼出号码 当有电话接通时,控制台会显示[onedial]CONNECTED 当有电话断开时,控制台会显示[onedial]DISCONNECTED 例子1: DIAL,117 屏幕回显[onedial]DIALING,117 接通后屏幕回显[onedial]CONNECTED HUNGUP 电话主动挂断并回显[onedial]DISCONNECTED 例子2: 外部电话主动呼入 屏幕显示[onedial]INCOMING CALL,138XXXXXXXXX PICKUP 接听电话 接通后屏幕回显[onedial]CONNECTED HUNGUP 拒接电话 电话主动挂断并回显[onedial]DISCONNECTED
功能:文本朗读,在官方库基础上增加了几个符号的朗读
朗读完成后,系统会收到TTSPLUS,XXX->DONE的消息 使用TTS,XXX 则使用原生库朗读对应的XXX 朗读完成后,系统会收到TTS,XXX->DONE的消息
功能:短信收发 发送短信
发送完成后,控制台收到完成短信SENDING TO 13XXXXXXXXX 发送的内容 接收短信 当模块收到短信后控制台显示 [SMS]收到的内容@发送的手机号码 例子 SMS,13000000000,这是发送给老米的一条骚扰短信,号码被隐去 发送成功后控制台回显 SMS,13XXXXXXXXX,这是发送给老米的一条骚扰短信->DONE
连线方法:MOSI/P11<->DIN,VLCD<->VCC,GND<->GND 使用方法:
显示完毕后回显2812DISPLAY,str->DONE 例子: 2812DISPLAY,HELLO LUAT 显示完毕后回显2812DISPLAY,HELLO LUAT->DONE
连线方式:CK<->CLK,DA<->DATA,RST<->RESET,DC<->Data/Command,CS<->CS,VLCD<->VDD_LCD,GND<->GND 功能:驱动160X128分辨率的st7735显示屏幕 在屏幕上显示文本
显示完成后,回显7735DISPLAY,Text->DONE 例子: 775DISPLAY,你好 屏幕从起始位置显示“你好” 显示完毕后,控制台回显7735DISPLAY,你好->DONE
连线方式:CK<->CLK,DA<->DATA,RST<->RESET,DC<->Data/Command,CS<->CS,VLCD<->VDD_LCD,GND<->GND 功能:驱动240X240分辨率的gc0a01圆形显示屏幕 在屏幕上指定行显示文本,文本自动居中
显示完成后,回显9A01DISPLAY,Xline,Text->DONE
例子: 9A01DISPLAY,你好 屏幕中间显示“你好” 显示完毕后,控制台回显9A01DISPLAY,你好->DONE
连线方法:SCL<->SCL,SDA<->SDA,VLCD<-VCC,GND<->GND 使用方法
例子: SHT30 Temperature:27.20 ,Humudity:52.10
作用:通过外部连接Air530GPS模块实现GPS定位,GPS端口号和波特率可以在midemo.bs中设置,默认为COM1 使用方法
返回如下格式数据: Satellite_Located:TRUE/FALSE,Longitude:XX.XXXXX,Latitude:XX.XXXXX,Altitude:XX.XXXXX,Speed:xx.xxxxx,Course,XX.XXXXX,ViewedSatelliteCount:XX,UsedSatelliteCount:XX<>
连线方法: VCC,驱动电源,+5~24V, 红 GND,地线,GND,黑 STEP,脉冲信号,P11,MOSI,白 DIR,方向,P18,黄 ENA,使能,P19,橙 COM,数字电源,VLCD,绿 开关1,2,3,4设置为OFF,ON,ON,OFF 功能:使步进电机旋转指定角度,角度最小分度为1度
系统返回Forwarding:xxxdegree,或者Reversing:xxxdegree 旋转到位后返回MOTOROLL,Degree->Done 例子: MOTOROLL,360 系统返回:Forwarding:360degree 旋转后返回MOTOROLL,360->DONE
本demo集源于上海合宙官方技术团队的DEMO(MIT),并参考了合宙开源社区的众多大佬无私分享的代码,包括但不限于 稀饭放姜、Wendal、晨旭、陈夏等
目前参考到的开源项目有: iRTU(MIT)、LuatOS(MIT)、LLCOM
欲获取更多luat 代码请访问 doc.openluat.com
如果您觉得本demo集包含了未经由您授权的代码,请联系 64034373@qq.com,如有侵权嫌疑将立即纠正
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。