用ESP8266+android,制作自己的WIFI小车(ESP8266篇)-阿里云开发者社区

开发者社区> 杨奉武> 正文

用ESP8266+android,制作自己的WIFI小车(ESP8266篇)

简介: 整体思路ESP8266作为TCP服务器,,手机作为TCP客户端,自己使用Lua直接做到了芯片里面,省了单片机,,节约成本,其实本来就是个单片机(感觉Lua开发8266真的很好,甩AT指令好几条街,,而且很容易上手,),不过呢,等几天我也会做一个51用AT指令的.
+关注继续查看

整体思路ESP8266作为TCP服务器,,手机作为TCP客户端,自己使用Lua直接做到了芯片里面,省了单片机,,节约成本,其实本来就是个单片机(感觉Lua开发8266真的很好,甩AT指令好几条街,,而且很容易上手,),不过呢,等几天我也会做一个51用AT指令的.....强烈建议学习使用Lua开发8266,不要偷懒.....如果谁说难我是不信,,那是因为没有认真去学....下面我会讲的很详细,,,,,让亲们感受一下Lua到底难不难......

因为最近看到朋友遇到各种各样的问题,,我会把遇到的问题统统说一下,,,,,,,

手机界面上放置四个按钮,代表前进,后退,左转,和右转,,,另外呢利用手机的重力感应传感器通过手机的倾斜角度控制小车的速度

前进,后退,左转,右转分别控制ESP8266的一个引脚,,,,速度数据呢是控制ESP8266一个引脚的PWM的占空比

连接

 

关于板子的引脚

 

如果发现轮子转的方向不对自己可以调换一下线哈,,,,,,,,,,

 

 现在做ESP8266部分

 第一件事情是刷固件

固件的自己可以去下载

官网下载地址

https://nodemcu-build.com/

如果自己不想自己去下载或者说不愿意去尝试,那么可以下载我自己下载好的,,,,,每一次改变总需要一个开始......希望亲们自己去官网下载

链接:http://pan.baidu.com/s/1jICE1GM 密码:qn69

 

对了还有Lua开发的API文档

 

https://nodemcu.readthedocs.io/en/master/en/modules/gpio/

还有一个简洁版的API资料

链接:http://pan.baidu.com/s/1pL3FHgf 密码:l2nm

 再者呢!有些时候需要写Lua语言自带的API函数

链接:http://pan.baidu.com/s/1pLjycR5 密码:qxk8

还有一个简洁版的

链接:http://pan.baidu.com/s/1o8T1nU6 密码:eglx

其实我也写了Lua的入门教程,,很多人都抱怨难难难,,现在自己用Lua开发却是得心应手,,正是之前所做过的那些努力,,当时也没人教自己,要知道自己花了1个多月才摸索到入门的,只感叹没有遇到引导者.....现在只想让别人不再走这么多的弯路,,,简直是煎熬......现在看来Lua开发8266真心不难....但是总需要经历一下过程........最起码最基本的语法还是要懂得吧.......其实只要知道语法,变量也就够了.....其余的就是调用调用

 

 

 

 都不用选

 

 

 然后就会出现下面的界面,,等着哈

选中地址下载就行

 

 

烧写固件的软件(一)

链接: http://pan.baidu.com/s/1cpnbVw 密码:2nha

 烧写固件的软件(二)

链接:http://pan.baidu.com/s/1boBW4N1 密码:88my

 无论哪一个软件,模块的接线都一样

 

 

GPIO0 默认是工作模式(不接线)。如果接了低电平就是下载模式(给模块刷固件!!)所以接低电平。CH_PD接高电平,其余除了TX,RX外可以不接线..

其实在模块上电的时候如果GPIO0是低电平那么模块就工作在等待刷固件模式,,,在模块上电的时候如果GPIO0是高电平那么模块就工作在正常工作模式,由于没有按键什么的,所以可以先接好线再上电

 

 

 

 

 先用第一个软件刷固件

 

 

 

 

选中,,地址是0000

然后呢

 

 

 

 

然后,复位一下

 

看一下真实的连接

 

 

 

 我的手机镜头晚上拍照感觉有一层东西...........

 

 好了

 

 

 现在看用第二个软件刷固件

 

 

 选择固件

给大家各种模块的Flash大小的表

http://wiki.ai-thinker.com/_media/esp8266/esp8266_module_list.png

 

接上跳线帽,,然后,复位一下

 

好了

 

对了可能出现

 

这呢是串口模块和WIFI模块通信不稳定导致的,,,自己用ch340就出现过这种情况,,,,但是用pl2303就没有出现过,,,,对于这种情况,我感觉第一有条件可以换一个串口模块,比如pl2303,或者CP2102等等...再者呢可以选择好的杜邦线,,尽量短......

不过呢,,用pl2303下载好以后,,用ch340也可以了...............

对了也可以尝试

把这里改小一点

感觉只要不通信那么多数据,,也能减少出错的机会

 现在用串口助手看一下

软件

 链接:http://pan.baidu.com/s/1qYqh9O4 密码:ddva

 

 

 

 

 如果出现--正在格式化文件系统就等着哈,,

 

大约不到一分钟

用Lua开发8622用这个软件

 http://pan.baidu.com/s/1kVN09cr  密码:pfv7

 

 

 如果点击的时候提示安装,,安装就行,,如果没有提示呢可以,按照下面链接的提示自己安装哈,,,,,或者自己百度

http://jingyan.baidu.com/article/3c343ff70bc6ea0d377963df.html

 

 

 

最新版本只有64位的

 

 

 

 

现在新建一个init.lua

 

 如果出现

然后写上

gpio.write(8,0)
gpio.write(7,0)
gpio.write(6,0)
gpio.write(5,0)
gpio.mode(8,gpio.OUTPUT)--cs--
gpio.mode(7,gpio.OUTPUT)--mosi--
gpio.mode(6,gpio.OUTPUT)--miso--
gpio.mode(5,gpio.OUTPUT)--clk--

pwm.setup(4, 1000, 500)
pwm.start(4)

 

 

一上电都是低电平保证不让小车动....

对了想控制GPIO15其实是写的

 

下面是对应关系

 

 我是把8266的SPI引脚引出来了,不过呢,只是当普通引脚使用

想了解SPI可以看这篇文章

http://www.cnblogs.com/yangfengwu/p/7524297.html

现在看控制速度的PWM引脚

 

感觉初始化的时候,占空比应该为0(一直是低电平),这样的话小车保证不会动

大家看后面注释一定能看明白..........而且还有例子..........

 

 如果出现

 

 可以先复位一下然后再执行操

对了要是经常出现编译或者下载到模块出问题.........一定是串口模块和WIFI模块通信之间有问题.....尽量使用好的杜邦线,,,尽量短,,,,,再者可以考虑换成pl2303或者CP2102等.......因为自己测试的这两种模块比较可靠

 

 

 因为GPIO2是WIFI模块上面的灯,,由于执行了PWM所以会看到这个这个灯微弱的发光

 

 现在再新建一个wifi.lua

 

把下面的代码复制粘贴过去

详细可以参考我的这几篇(由于有些朋友说还是不够详细,,,,后期这几篇我会再在里面详细添加内容)

看完这几篇开发8266一定会让您感觉有了新的突破

一   http://www.cnblogs.com/yangfengwu/p/7514336.html      下载自己选择功能的固件,刷固件,写LUA的软件

二    http://www.cnblogs.com/yangfengwu/p/7520260.html     GPIO,串口,注意事项,空闲中断

三    http://www.cnblogs.com/yangfengwu/p/7524297.html      SPI通信介绍,,STM32 SPI 从机

四    http://www.cnblogs.com/yangfengwu/p/7524326.html      TCP服务器,单个连接

五    http://www.cnblogs.com/yangfengwu/p/7531730.html      TCP服务器,多个客户端连接,CRC校验

六    http://www.cnblogs.com/yangfengwu/p/7533302.html       TCP Client 断开自动重连,AD采集

七    http://www.cnblogs.com/yangfengwu/p/7533845.html      UDP支持一路默认,3路动态连接,ssid 与 pwd 的读取

八    http://www.cnblogs.com/yangfengwu/p/7534521.html       ESP8266 文件保存数据(基于Lua脚本语言)

 

wifi.setmode(wifi.STATIONAP)

cfg={}
cfg.ssid="Hellow8266"
cfg.pwd="11223344"
wifi.ap.config(cfg)

apcfg={}
apcfg.ssid="qqqqq"
apcfg.pwd="11223344"
wifi.sta.config(apcfg)
wifi.sta.connect()

TCPSever=net.createServer(net.TCP,28800) 

TcpConnectCnt = 0
TcpSocketTable={}
NowSocket=nil
TCPSever:listen(8080,function(socket) 
  
    if  TcpConnectCnt == 4 then
        if  TcpSocketTable[0] ~= nil then 
            TcpSocketTable[0]:close()
            TcpSocketTable[0] = nil
        end    
    else
        if  TcpSocketTable[TcpConnectCnt+1] ~= nil then 
            TcpSocketTable[TcpConnectCnt+1]:close()
            TcpSocketTable[TcpConnectCnt+1] = nil
        end 
    end
    
    TcpSocketTable[TcpConnectCnt] = socket
    
    print(TcpConnectCnt.."-Connect")
    
    
    TcpConnectCnt = TcpConnectCnt + 1
    if  TcpConnectCnt == 5 then
        TcpConnectCnt = 0
    end
    
    
    socket:on("receive",function(socket,data) 
          NowSocket = socket
          uart.write(0,data) 
          control(data)
    end) 

    socket:on("disconnection",function(sck,c) 
        for i=0,4 do
            if  TcpSocketTable[i] == sck then
                TcpSocketTable[i] = nil
                print(i.."-Disconnect")
            end
        end
    end)
    
end)


function control(data)  
    local RevLen = string.len (data)

    --[[
    local i; local datatable={};
    for  i=1,RevLen do
         datatable[i] = data:byte(i);
    end
    print(CRC16Flage(datatable,6))]]
    
    
    local crc = ow.crc16(string.sub(data,1,RevLen-2))
    local recrc = data:byte(RevLen)
    local recrc = recrc*256
    local recrc = recrc + data:byte(RevLen-1)
    
    if  crc == recrc then
        if  RevLen == 6 then
            if  data:byte(1) == 0xAA and data:byte(2) == 0x55 then
                stopcar = 0;
                if  data:byte(3) == 0x01 then--forward
                    gpio.write(8,1)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,1)--you qian
                    gpio.write(5,0)--you hou
                    --print("forward")
                end
                if  data:byte(3) == 0x02 then--back
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,1)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,1)--you hou
                    --print("back")
                end
                if  data:byte(3) == 0x03 then--right
                    gpio.write(8,1)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,1)--you hou
                    --print("right")
                end
                if  data:byte(3) == 0x04 then--left
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,1)--zuo hou
                    gpio.write(6,1)--you qian
                    gpio.write(5,0)--you hou
                    --print("left")
                end
                if  data:byte(3) == 0x05 then--stop
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,0)--you hou
                    --print("stop")
                end
                pwm.setduty(4, data:byte(4)*10)
            end
        end
    else
        if  NowSocket ~= nil then
                --NowSocket:send("CRC16 Faild")
                NowSocket = nil
        end   
    end       
end  

stopcar = 0;
tmr.alarm(1, 100, 1, function()
    stopcar = stopcar + 1;
    if  stopcar>3 then
        stopcar = 3;
        gpio.write(8,0)--zuo qian
        gpio.write(7,0)--zuo hou
        gpio.write(6,0)--you qian
        gpio.write(5,0)--you hou
    end
end)


--计算CRC
function  CRC16(modbusdata,length)
    local i=0;local j=0;local crc=0;local k=1;local l=1;
    
    for k=1 ,length do
        crc = bit.bxor(crc,modbusdata[k])
        for l=1,8 do
            if  bit.band(crc,1) == 1 then
                crc = bit.rshift(crc,1);
                crc = bit.bxor(crc,0xa001);
            else
                crc = bit.rshift(crc,1);
            end
        end
    end
    return crc;
end

function CRC16Flage(modbusdata,length)
    local Receive_CRC = 0;local calculation = 1;
    Receive_CRC = CRC16(modbusdata,length-2)
    calculation = modbusdata[length];
    calculation = calculation * 256;
    calculation = calculation + modbusdata[length-1];
    if  Receive_CRC == calculation then
        return 1;
    else
        return 0;    
    end
end



uart.on("data",0,function(data) 

    for i=0,4 do
        if  TcpSocketTable[i] ~= nil then
            TcpSocketTable[i]:send(data)
        end
    end
        
end, 0)


printip = 0
wifi.eventmon.register(wifi.eventmon.STA_DISCONNECTED, function(T)
    printip = 0
end)


wifi.eventmon.register(wifi.eventmon.STA_GOT_IP, function(T)
   if printip == 0 then
      print("+IP"..T.IP)
   end
   printip = 1
end)

 

 

 

 用uart.write(0,data),,和print(data)的区别在于uart就相当于咱们单片机常用的串口发送.....而print相当于printf

而且这个print呢默认是遇到'\0'就把这之前的数据发到串口,,所以呢有时候您定义的数据如果有'0',,,,那么这个'0'后面的数据就发不过去了........

 有些人会问,为什么要这样做呢,,,函数为什么是这样....当然是看的API文档啦

 

 

 

 API函数很多,,其实无论做什么东西您一定要知道自己想做什么东西,,需要什么功能,然后根据这些去找符合自己需求的API,自己心中一定要有数,,无论做什么东西都是这样...一定是自己先全方面的把握好整体,,然后再进行拆分成各个模块,然后再进行组合..............

所以自己做东西前一些天自己进度很慢很慢,我会考虑哪些模块自己并不会,但是一定会用到,我就会先攻克这块,一定是先把自己不懂或者不会的解决掉,因为如果不解决掉,这一块如果牵扯到别的模块就麻烦了....然后感觉可以了呢!就再花些时间整合一下系统,,,再考虑考虑整个系统所涉及的地方,,可能遇到的问题,尽量杀死在摇篮里面....然后呢就把整个系统做一下拆分,,,如何拆分就看自己的了,经验越多越拆分的合理......感觉可以了,,,开始干了,前期的投入就会发现大有成效,后期会节省很多时间........

很多人问我辞职原因:在我手里做的东西首先要让自己认可,解决当前的问题并不是我为了炫耀什么,这是我自己做东西的底线,我一直相信办法总比困难多,我要的是合作伙伴;我虽然都是自学的,但是我才会对整个系统把握的更好,因为我总是在做整个系统的东西;我从来不会拿公司项目开玩笑,我说在规定时间内能完成就绝对能完成;我要的是做好;解决一个技术难题我认为是自己应该做的,但绝对不会误期,因为如果我觉得会超过时间,我也就不会现在去解决了,我就会留到以后了;

解决的问题 :

http://www.cnblogs.com/yangfengwu/p/6870331.html

看看程序看一看哪里有不会的就赶紧去查资料哈......QQ号和群都在上面显示着呢

其实呢官方只是提供了这些API函数,,,具体里面实现什么具体功能就看自己的了......

 

 现在看数据处理函数

function control(data)  
    local RevLen = string.len (data)

    --[[
    local i; local datatable={};
    for  i=1,RevLen do
         datatable[i] = data:byte(i);
    end
    print(CRC16Flage(datatable,6))]]
    
    
    local crc = ow.crc16(string.sub(data,1,RevLen-2))
    local recrc = data:byte(RevLen)
    recrc = recrc*256
    recrc = recrc + data:byte(RevLen-1)
    
    if  crc == recrc then
        if  RevLen == 6 then
            if  data:byte(1) == 0xAA and data:byte(2) == 0x55 then
                stopcar = 0;
                if  data:byte(3) == 0x01 then--forward
                    gpio.write(8,1)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,1)--you qian
                    gpio.write(5,0)--you hou
                    --print("forward")
                end
                if  data:byte(3) == 0x02 then--back
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,1)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,1)--you hou
                    --print("back")
                end
                if  data:byte(3) == 0x03 then--right
                    gpio.write(8,1)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,1)--you hou
                    --print("right")
                end
                if  data:byte(3) == 0x04 then--left
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,1)--zuo hou
                    gpio.write(6,1)--you qian
                    gpio.write(5,0)--you hou
                    --print("left")
                end
                if  data:byte(3) == 0x05 then--stop
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,0)--you hou
                    --print("stop")
                end
                pwm.setduty(4, data:byte(4)*10)
            end
        end
    else
        if  NowSocket ~= nil then
                --NowSocket:send("CRC16 Faild")
                NowSocket = nil
        end   
    end       
end 

 

 

我规定的

前进  0xAA,0x55,0x01,((传过来的数0-100,根据手机倾斜角度)速度PWM),CRC16低位,CRC16高位

后退  0xAA,0x55,0x02,((传过来的数0-100,根据手机倾斜角度)速度PWM),CRC16低位,CRC16高位

右转  0xAA,0x55,0x03,((传过来的数0-100,根据手机倾斜角度)速度PWM),CRC16低位,CRC16高位

左转  0xAA,0x55,0x04,((传过来的数0-100根据手机倾斜角度)速度PWM),CRC16低位,CRC16高位

停止  0xAA,0x55,0x05,((0)速度PWM),CRC16低位,CRC16高位

所以现在看一下

下面是自己写的CRC16校验,,对于不是提供了CRC16校验了,为什么还要自己写,...看下面哈

--计算CRC
function  CRC16(modbusdata,length)
    local i=0;local j=0;local crc=0;local k=1;local l=1;
    
    for k=1 ,length do
        crc = bit.bxor(crc,modbusdata[k])
        for l=1,8 do
            if  bit.band(crc,1) == 1 then
                crc = bit.rshift(crc,1);
                crc = bit.bxor(crc,0xa001);
            else
                crc = bit.rshift(crc,1);
            end
        end
    end
    return crc;
end

function CRC16Flage(modbusdata,length)//这个呢为了检测数据方便直接把数据往里面一丢,直接判断返回的如果是1说明crc正确,,否则0错误
    local Receive_CRC = 0;local calculation = 1;
    Receive_CRC = CRC16(modbusdata,length-2)
    calculation = modbusdata[length];
    calculation = calculation * 256;
    calculation = calculation + modbusdata[length-1];
    if  Receive_CRC == calculation then
        return 1;
    else
        return 0;    
    end
end

下面还有android的呢!!算法都一样,,,只不过会告诉亲们注意的问题

 

 

 

 

我重新把wifi,lua贴一下

wifi.setmode(wifi.STATIONAP)

cfg={}
cfg.ssid="Hellow8266"
cfg.pwd="11223344"
wifi.ap.config(cfg)

apcfg={}
apcfg.ssid="qqqqq"
apcfg.pwd="11223344"
wifi.sta.config(apcfg)
wifi.sta.connect()

TCPSever=net.createServer(net.TCP,28800) 

TcpConnectCnt = 0
TcpSocketTable={}
NowSocket=nil
TCPSever:listen(8080,function(socket) 
  
    if  TcpConnectCnt == 4 then
        if  TcpSocketTable[0] ~= nil then 
            TcpSocketTable[0]:close()
            TcpSocketTable[0] = nil
        end    
    else
        if  TcpSocketTable[TcpConnectCnt+1] ~= nil then 
            TcpSocketTable[TcpConnectCnt+1]:close()
            TcpSocketTable[TcpConnectCnt+1] = nil
        end 
    end
    
    TcpSocketTable[TcpConnectCnt] = socket
    
    print(TcpConnectCnt.."-Connect")
    
    
    TcpConnectCnt = TcpConnectCnt + 1
    if  TcpConnectCnt == 5 then
        TcpConnectCnt = 0
    end
    
    
    socket:on("receive",function(socket,data) 
          NowSocket = socket
          uart.write(0,data) 
          control(data)
    end) 

    socket:on("disconnection",function(sck,c) 
        for i=0,4 do
            if  TcpSocketTable[i] == sck then
                TcpSocketTable[i] = nil
                print(i.."-Disconnect")
            end
        end
    end)
    
end)


function control(data)  
    local RevLen = string.len (data)

    --[[
    local i; local datatable={};
    for  i=1,RevLen do
         datatable[i] = data:byte(i);
    end
    print(CRC16Flage(datatable,6))]]
    
    
    local crc = ow.crc16(string.sub(data,1,RevLen-2))
    local recrc = data:byte(RevLen)
    recrc = recrc*256
    recrc = recrc + data:byte(RevLen-1)
    
    if  crc == recrc then
        if  RevLen == 6 then
            if  data:byte(1) == 0xAA and data:byte(2) == 0x55 then
                stopcar = 0;
                if  data:byte(3) == 0x01 then--forward
                    gpio.write(8,1)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,1)--you qian
                    gpio.write(5,0)--you hou
                    --print("forward")
                end
                if  data:byte(3) == 0x02 then--back
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,1)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,1)--you hou
                    --print("back")
                end
                if  data:byte(3) == 0x03 then--right
                    gpio.write(8,1)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,1)--you hou
                    --print("right")
                end
                if  data:byte(3) == 0x04 then--left
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,1)--zuo hou
                    gpio.write(6,1)--you qian
                    gpio.write(5,0)--you hou
                    --print("left")
                end
                if  data:byte(3) == 0x05 then--stop
                    gpio.write(8,0)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,0)--you hou
                    --print("stop")
                end
                pwm.setduty(4, data:byte(4)*10)
            end
        end
    else
        if  NowSocket ~= nil then
                --NowSocket:send("CRC16 Faild")
                NowSocket = nil
        end   
    end       
end  

stopcar = 0;
tmr.alarm(1, 100, 1, function()
    stopcar = stopcar + 1;
    if  stopcar>3 then
        stopcar = 3;
        gpio.write(8,0)--zuo qian
        gpio.write(7,0)--zuo hou
        gpio.write(6,0)--you qian
        gpio.write(5,0)--you hou
    end
end)


--计算CRC
function  CRC16(modbusdata,length)
    local i=0;local j=0;local crc=0;local k=1;local l=1;
    
    for k=1 ,length do
        crc = bit.bxor(crc,modbusdata[k])
        for l=1,8 do
            if  bit.band(crc,1) == 1 then
                crc = bit.rshift(crc,1);
                crc = bit.bxor(crc,0xa001);
            else
                crc = bit.rshift(crc,1);
            end
        end
    end
    return crc;
end

function CRC16Flage(modbusdata,length)
    local Receive_CRC = 0;local calculation = 1;
    Receive_CRC = CRC16(modbusdata,length-2)
    calculation = modbusdata[length];
    calculation = calculation * 256;
    calculation = calculation + modbusdata[length-1];
    if  Receive_CRC == calculation then
        return 1;
    else
        return 0;    
    end
end



uart.on("data",0,function(data) 

    for i=0,4 do
        if  TcpSocketTable[i] ~= nil then
            TcpSocketTable[i]:send(data)
        end
    end
        
end, 0)


printip = 0
wifi.eventmon.register(wifi.eventmon.STA_DISCONNECTED, function(T)
    printip = 0
end)


wifi.eventmon.register(wifi.eventmon.STA_GOT_IP, function(T)
   if printip == 0 then
      print("+IP"..T.IP)
   end
   printip = 1
end)

 

 如果出现

复位一下,然后再

 

 如果出现

其实也是

对了要是经常出现编译或者下载到模块出问题.........一定是串口模块和WIFI模块通信之间有问题.....尽量使用好的杜邦线,,,尽量短,,,,,再者可以考虑换成pl2303或者CP2102等.......因为自己测试的这两种模块比较可靠

 其实也可以复位一下再

 

 对了开头就说模块默认上电是执行init.lua,所以呢需要在init.lua中调用wifi.lua

现在的init.lua变为

gpio.write(8,0)
gpio.write(7,0)
gpio.write(6,0)
gpio.write(5,0)
gpio.mode(8,gpio.OUTPUT)--cs--
gpio.mode(7,gpio.OUTPUT)--mosi--
gpio.mode(6,gpio.OUTPUT)--miso--
gpio.mode(5,gpio.OUTPUT)--clk--

pwm.setup(4, 1000, 500)
pwm.start(4)

tmr.alarm(0, 2000, 0, function()
    dofile("wifi.lua")
end)

复位一下

现在打开手机看一下已经有了WiFi的无线了....连接它,,密码是程序中设置的11223344

 

 APP软件链接

链接:http://pan.baidu.com/s/1miBo3e4 密码:88lr

 现在您就可以控制自己的小车了..........

不过这样连接会发现有问题......一上电轮子会转一下再停...........

原因是PWM的引脚接的是Wifi模块灯上的引脚,而且呢灯的负极是接到WiFi模块的......所以一上电PWM会是一个高点的电平...........

 

 再看第二个原因,,,会发现为什么只有左轮转......右轮为什么不转呢.........

那是由于其实一开始都应该是高电平...但是CS引脚拉低了........造成了左前(低),左后(高),右前(高),右后(高)....所以左轮就倒转了............

 

 

知道了原因,,就好解决问题了.....

第一种方案,,,把PWM(GPIO2)换成左前CS(GPIO15)引脚,,,因为一上电是低电平所以由于没有PWM,,绝对不会转,,改一下程序,,换一下引脚

第二种方案自己再用一个10K的电阻也把左后(MOSI,GPIO13)拉低,,,,,最简单的方案

第三种方案,,自己板子上有一个继电器,,可以先把PWM(GPIO2)接到继电器的输出COM端,然后把继电器的常开触点接到L298N的PWM控制引脚,,在程序里呢先控制控制方向的引脚输出低电平,然后再设置好PWM,然后再控制继电器吸合,,,因为按下复位后,控制继电器的引脚没有那个能力驱动继电器了....就会断开PWM,,,所以轮子也不会转

我们采用第一种方案,修改的地方最多的方案,,,要不怕麻烦,这样才会学的更多,理解的更深刻,,这篇博客现在已经用了快2天的时间了,边写边测试,希望自己能够遇到所有的问题

 换一下连接

 

 好现在的init.lua

--gpio.write(8,0)
gpio.write(4,0)
gpio.write(7,0)
gpio.write(6,0)
gpio.write(5,0)
--gpio.mode(8,gpio.OUTPUT)--cs--
gpio.mode(4,gpio.OUTPUT)--cs--
gpio.mode(7,gpio.OUTPUT)--mosi--
gpio.mode(6,gpio.OUTPUT)--miso--
gpio.mode(5,gpio.OUTPUT)--clk--


pwm.setup(8, 1000, 0)
pwm.start(8)

tmr.alarm(0, 2000, 0, function()
    dofile("wifi.lua")
end)

wifi.lua

 

 

wifi.setmode(wifi.STATIONAP)

cfg={}
cfg.ssid="Hellow8266"
cfg.pwd="11223344"
wifi.ap.config(cfg)

apcfg={}
apcfg.ssid="qqqqq"
apcfg.pwd="11223344"
wifi.sta.config(apcfg)
wifi.sta.connect()

TCPSever=net.createServer(net.TCP,28800) 

TcpConnectCnt = 0
TcpSocketTable={}
NowSocket=nil
TCPSever:listen(8080,function(socket) 
  
    if  TcpConnectCnt == 4 then
        if  TcpSocketTable[0] ~= nil then 
            TcpSocketTable[0]:close()
            TcpSocketTable[0] = nil
        end    
    else
        if  TcpSocketTable[TcpConnectCnt+1] ~= nil then 
            TcpSocketTable[TcpConnectCnt+1]:close()
            TcpSocketTable[TcpConnectCnt+1] = nil
        end 
    end
    
    TcpSocketTable[TcpConnectCnt] = socket
    
    print(TcpConnectCnt.."-Connect")
    
    
    TcpConnectCnt = TcpConnectCnt + 1
    if  TcpConnectCnt == 5 then
        TcpConnectCnt = 0
    end
    
    
    socket:on("receive",function(socket,data) 
          NowSocket = socket
          uart.write(0,data) 
          control(data)
    end) 

    socket:on("disconnection",function(sck,c) 
        for i=0,4 do
            if  TcpSocketTable[i] == sck then
                TcpSocketTable[i] = nil
                print(i.."-Disconnect")
            end
        end
    end)
    
end)


function control(data)  
    local RevLen = string.len (data)

    --[[
    local i; local datatable={};
    for  i=1,RevLen do
         datatable[i] = data:byte(i);
    end
    print(CRC16Flage(datatable,6))]]
    
    
    local crc = ow.crc16(string.sub(data,1,RevLen-2))
    local recrc = data:byte(RevLen)
    recrc = recrc*256
    recrc = recrc + data:byte(RevLen-1)
    
    if  crc == recrc then
        if  RevLen == 6 then
            if  data:byte(1) == 0xAA and data:byte(2) == 0x55 then
                stopcar = 0;
                if  data:byte(3) == 0x01 then--forward
                    gpio.write(4,1)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,1)--you qian
                    gpio.write(5,0)--you hou
                    --print("forward")
                end
                if  data:byte(3) == 0x02 then--back
                    gpio.write(4,0)--zuo qian
                    gpio.write(7,1)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,1)--you hou
                    --print("back")
                end
                if  data:byte(3) == 0x03 then--right
                    gpio.write(4,1)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,1)--you hou
                    --print("right")
                end
                if  data:byte(3) == 0x04 then--left
                    gpio.write(4,0)--zuo qian
                    gpio.write(7,1)--zuo hou
                    gpio.write(6,1)--you qian
                    gpio.write(5,0)--you hou
                    --print("left")
                end
                if  data:byte(3) == 0x05 then--stop
                    gpio.write(4,0)--zuo qian
                    gpio.write(7,0)--zuo hou
                    gpio.write(6,0)--you qian
                    gpio.write(5,0)--you hou
                    --print("stop")
                end
                pwm.setduty(8, data:byte(4)*10)
            end
        end
    else
        if  NowSocket ~= nil then
                --NowSocket:send("CRC16 Faild")
                NowSocket = nil
        end   
    end       
end  

stopcar = 0;
tmr.alarm(1, 100, 1, function()
    stopcar = stopcar + 1;
    if  stopcar>3 then
        stopcar = 3;
        gpio.write(4,0)--zuo qian
        gpio.write(7,0)--zuo hou
        gpio.write(6,0)--you qian
        gpio.write(5,0)--you hou
    end
end)


--计算CRC
function  CRC16(modbusdata,length)
    local i=0;local j=0;local crc=0;local k=1;local l=1;
    
    for k=1 ,length do
        crc = bit.bxor(crc,modbusdata[k])
        for l=1,8 do
            if  bit.band(crc,1) == 1 then
                crc = bit.rshift(crc,1);
                crc = bit.bxor(crc,0xa001);
            else
                crc = bit.rshift(crc,1);
            end
        end
    end
    return crc;
end

function CRC16Flage(modbusdata,length)
    local Receive_CRC = 0;local calculation = 1;
    Receive_CRC = CRC16(modbusdata,length-2)
    calculation = modbusdata[length];
    calculation = calculation * 256;
    calculation = calculation + modbusdata[length-1];
    if  Receive_CRC == calculation then
        return 1;
    else
        return 0;    
    end
end



uart.on("data",0,function(data) 

    for i=0,4 do
        if  TcpSocketTable[i] ~= nil then
            TcpSocketTable[i]:send(data)
        end
    end
        
end, 0)


printip = 0
wifi.eventmon.register(wifi.eventmon.STA_DISCONNECTED, function(T)
    printip = 0
end)


wifi.eventmon.register(wifi.eventmon.STA_GOT_IP, function(T)
   if printip == 0 then
      print("+IP"..T.IP)
   end
   printip = 1
end)

先下载wifi.lua哈,,,因为init.lua是调用wifi.lua,,,如果不先下载wifi.lua就会调用报错.....

如果出现

可以先把wifi模块里面的init.lua移除掉或者全部文件移除掉...再编译下载wifi.lua

方法是

先编译一个小的文件,,我们的init比较小

 

 然后看右边

 

 我们把init.lua移除,,,注意哈是事先准备好,然后复位一下模块然后再点击

 

 然后再复位一下模块看看

现在重新下载wifi.lua把

 

我都是复位,,停1s左右编译,,,,然后复位,,停1s左右下载

 如果还有问题可以考虑把所有文件移除掉

复位后再点击哈...因为一开始上电趁模块还没操作影响下载的程序时才可以哈......点击后需要等5~6秒哈......然后再复位一下模块,然后重新下载吧

 好了底层做好了...现在做手机APP,我需要关一下电脑,,,工作时间太长,,有点卡.....这篇文章也写得够多的了,,我单独写一篇文章介绍APP

链接:http://www.cnblogs.com/yangfengwu/p/7633980.html

先奉上实物链接,APP源码链接

https://item.taobao.com/item.htm?spm=a1z10.1-c-s.w4004-15892851284.24.40c1a34cvT6L6W&id=559542734694

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
使用NAT网关轻松为单台云服务器设置多个公网IP
在应用中,有时会遇到用户询问如何使单台云服务器具备多个公网IP的问题。 具体如何操作呢,有了NAT网关这个也不是难题。
25920 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
7238 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,大概有三种登录方式:
2503 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
8920 0
windows server 2008阿里云ECS服务器安全设置
最近我们Sinesafe安全公司在为客户使用阿里云ecs服务器做安全的过程中,发现服务器基础安全性都没有做。为了为站长们提供更加有效的安全基础解决方案,我们Sinesafe将对阿里云服务器win2008 系统进行基础安全部署实战过程! 比较重要的几部分 1.
8120 0
阿里云服务器安全组设置内网互通的方法
虽然0.0.0.0/0使用非常方便,但是发现很多同学使用它来做内网互通,这是有安全风险的,实例有可能会在经典网络被内网IP访问到。下面介绍一下四种安全的内网互联设置方法。 购买前请先:领取阿里云幸运券,有很多优惠,可到下文中领取。
11673 0
腾讯云服务器 设置ngxin + fastdfs +tomcat 开机自启动
在tomcat中新建一个可以启动的 .sh 脚本文件 /usr/local/tomcat7/bin/ export JAVA_HOME=/usr/local/java/jdk7 export PATH=$JAVA_HOME/bin/:$PATH export CLASSPATH=.
4446 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,云吞铺子总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系统盘、创建快照、配置安全组等操作如何登录ECS云服务器控制台? 1、先登录到阿里云ECS服务器控制台 2、点击顶部的“控制台” 3、通过左侧栏,切换到“云服务器ECS”即可,如下图所示 通过ECS控制台的远程连接来登录到云服务器 阿里云ECS云服务器自带远程连接功能,使用该功能可以登录到云服务器,简单且方便,如下图:点击“远程连接”,第一次连接会自动生成6位数字密码,输入密码即可登录到云服务器上。
20957 0
+关注
杨奉武
优秀不够,你是否无可替代;知识从未如此性感 --群1: 235371864 --群2: 607064330 --QQ:946029359 --淘宝 https://shop411638453.taobao.com/
119
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《Nacos架构&原理》
立即下载
《看见新力量:二》电子书
立即下载
云上自动化运维(CloudOps)白皮书
立即下载