应该是LUA介绍8266的最后一篇,,,,,,下回是直接用SDK,,然后再列个12345.......不过要等一两个星期,先忙完朋友的事情
前面几篇
用AT指令版本的
一,http://www.cnblogs.com/yangfengwu/p/5205570.html发AT指令,,其实AT指令就是事先用SDK内部写好了
二,http://www.cnblogs.com/yangfengwu/p/5295632.html这个呢是配合路由器实现远程,,其实可以买个域名,或者用云端
三,http://www.cnblogs.com/yangfengwu/p/5220919.html这是做了一个用手机控制的WIFI小车
四,http://www.cnblogs.com/yangfengwu/p/5212570.htmlAndroid TCP客户端
五,http://www.cnblogs.com/yangfengwu/p/5294921.htmlAndroid TCP服务器
用LUA语言的,更灵活,功能更强
一http://www.cnblogs.com/yangfengwu/p/7514336.html下载自己选择功能的固件,刷固件,写LUA的软件
二http://www.cnblogs.com/yangfengwu/p/7520260.htmlGPIO,串口,注意事项,空闲中断
三http://www.cnblogs.com/yangfengwu/p/7524297.htmlSPI通信介绍,,STM32 SPI 从机
四http://www.cnblogs.com/yangfengwu/p/7524326.htmlTCP服务器,单个连接
五http://www.cnblogs.com/yangfengwu/p/7531730.htmlTCP服务器,多个客户端连接,CRC校验
六http://www.cnblogs.com/yangfengwu/p/7533302.htmlTCP Client 断开自动重连,AD采集
七http://www.cnblogs.com/yangfengwu/p/7533845.htmlUDP支持一路默认,3路动态连接,ssid 与 pwd 的读取
还缺一样....这篇...保存数据...这样的话就可以随意修改启动时工作在哪一种模式,哪一种通信,以及其余需要保存在模块内部的信息
就实现上位机软件的第一个功能,,修改启动模式
自己的上位机按钮事件
privatevoidbutton2_Click(objectsender, EventArgs e)
{byte[] sendbyte =newbyte[6];
sendbyte[0] = (byte)'+';//2Bsendbyte[1] = (byte)'+';
sendbyte[2] = (byte)'M';//4Dsendbyte[3] = (byte)'D';//44sendbyte[4] = (byte)'0';//0if(radioButton5.Checked)
{
sendbyte[5] = (byte)'0';
}elseif(radioButton6.Checked)
{
sendbyte[5] = (byte)'1';
}elseif(radioButton7.Checked)
{
sendbyte[5] = (byte)'2';
}if(radioButtonNetCon.Checked)
{
TcpSendDataMethod(sendbyte);
}elseif(radioButtonSerialCon.Checked)
{
SerialSend(sendbyte);
}
}
++MD00 AP模式
++MD01 Station模式
++MD00 AP+Station模式
其实最后还有CRC16校验码
看文件操作
iffile.open("mode.lua","w+") then
file.writeline(string.sub(data,6,6))--MODE
print("MODE="..string.sub(data,6,6))
file.close()elseprint("open mode.lua faild")
end
注意
iffile.open("mode.lua","w+") then
file.writeline("123")
file.flush()//连续写最好加上file.writeline("456")
file.flush()
file.writeline("789")
file.close()elseprint("open mode.lua faild")
end
像是这样 mode.lua文件里面会是这样
那么读的时候
file.open("mode.lua","r") then
s1=file.readline()
s2=file.readline()
s3=file.readline()
file.close()
end
s1 ="123\r"
s2 ="456\r"
s3 ="789\r"
所以写进去一行3个但是读出来会多加一个换行符
iffile.open("mode.lua","r") then
local Mode=file.readline()ifMode ==nil then
Mode="2"endifMode:byte(1) ==48then
print("Wifi MODE: SOFTAP")
wifi.setmode(wifi.SOFTAP)
elseif Mode:byte(1) ==49then
print("Wifi MODE: STATION")
wifi.setmode(wifi.STATION)elseprint("Wifi MODE: STATIONAP")
wifi.setmode(wifi.STATIONAP)
end
file.close()
end
直接上源码吧
init.lua
gpio.mode(4,gpio.OUTPUT)
gpio.mode(2,gpio.OUTPUT)
gpio.write(4,1)ifadc.force_init_mode(adc.INIT_ADC) then
node.restart()returnend
tmr.alarm(0,1000,1, function()
gpio.write(4,1-gpio.read(4))
end)
tmr.alarm(1,5000,0, function()
dofile("file.lua")
dofile("UDP.lua")
end)
UDP.lua
iffile.open("mode.lua","r") then
local Mode=file.readline()ifMode ==nil then
Mode="2"endifMode:byte(1) ==48then
print("Wifi MODE: SOFTAP")
wifi.setmode(wifi.SOFTAP)
elseif Mode:byte(1) ==49then
print("Wifi MODE: STATION")
wifi.setmode(wifi.STATION)elseprint("Wifi MODE: STATIONAP")
wifi.setmode(wifi.STATIONAP)
end
file.close()
end
cfg={}
cfg= wifi.ap.getconfig(true)ifcfg.ssid ==nil then
cfg.ssid="Hellow8266"cfg.pwd="11223344"end
print("APssid:"..cfg.ssid)ifcfg.pwd ==nil then
print("APpwd: nil")elseprint("APpwd:"..cfg.pwd)
end
cfg.save=truewifi.ap.config(cfg)
apcfg={}
apcfg= wifi.sta.getconfig(true)ifapcfg.ssid ==nil then
apcfg.ssid="qqqqq"apcfg.pwd="11223344"end
print("APssid:"..apcfg.ssid)ifapcfg.pwd ==nil then
print("Stationpwd: nil")elseprint("Stationpwd:"..apcfg.pwd)
end
apcfg.save=truewifi.sta.config(apcfg)
wifi.sta.autoconnect(1)
ConnectIP="192.168.1.103"ConnectPort=8080UdpSocket=net.createUDPSocket()
UdpSocket:listen(ConnectPort)
UdpSocketTable={}
UdpIPTable={}
UdpPortTable={}
UdpConnectCnt=0UdpCanConnect=0UdpSocket:on("receive", function(socket, data, port, ip)
UdpCanConnect=1fori=0,2doifUdpIPTable[i] == ip and UdpPortTable[i] ==port then
UdpCanConnect=0end
endifip == ConnectIP and port ==ConnectPort then
UdpCanConnect=0endifUdpCanConnect ==1then
UdpSocketTable[UdpConnectCnt]=socket
UdpIPTable[UdpConnectCnt]=ip
UdpPortTable[UdpConnectCnt]=port
print("\r\n"..UdpConnectCnt.."-Connect")
UdpConnectCnt= UdpConnectCnt +1endifUdpConnectCnt ==3then
UdpConnectCnt=0end
uart.write(0,data)
end)
UartReadCnt=0UartReadCntCopy=0UartReadData=""UartReadDataCopy=""uart.on("data",0,function(data)
UartReadCnt= UartReadCnt +1UartReadData=UartReadData..data
end,0)
tmr.alarm(2,5,1, function()ifUartReadCnt ~=0thenifUartReadCnt ==UartReadCntCopy then
UartReadCnt=0UartReadCntCopy=0UartReadDataCopy=UartReadData
UartReadData=""Config(UartReadDataCopy)
NetSend(UartReadDataCopy)elseUartReadCntCopy=UartReadCnt
end
end
end)
function NetSend(data)ifUdpSocket ~=nil then
UdpSocket:send(ConnectPort,ConnectIP,data)
endfori=0,2doifUdpSocketTable[i] ~=nil then
UdpSocketTable[i]:send(UdpPortTable[i],UdpIPTable[i],data)
end
end
end
printip=0wifi.eventmon.register(wifi.eventmon.STA_DISCONNECTED, function(T)
printip=0end)
wifi.eventmon.register(wifi.eventmon.STA_GOT_IP, function(T)ifprintip ==0then
print("+IP"..T.IP)
end
printip=1end)
file.lua
就是接收串口的数据函数,检测CRC对不对,,然后把数据写进mode.lua,,,对了这样设置了,,内部会自动生成一个mode.lua,,不用自己弄
function Config(data)
local RevLen=string.len (data)
local crc= ow.crc16(string.sub(data,1,RevLen-2))
local recrc= data:byte(RevLen)
recrc= recrc*256recrc= recrc + data:byte(RevLen-1)ifcrc ==recrc then--[[8266Mode ]]ifRevLen ==8thenifstring.sub(data,1,5) =="++MD0"then----Modeiffile.open("mode.lua","w+") then
file.writeline(string.sub(data,6,6))--MODE
print("MODE="..string.sub(data,6,6))
file.close()elseprint("open mode.lua faild")
end
end--[[8266Mode ]]
end
end
end
其实也没有说的了,串口用空闲中断接收的,前面说了,,,,剩下的主要是自己看着API文档自己测试测试哈
现在把程序下进去用上位机试一试修改模式
复位重启一下
对了我把UDP的修改了一个地方,,,写的太着急写错了,
这样才是判断是新的连接,而且不和默认的一样才执行后面的
完了一个大的心思