The wifi.sta module connects if a loop is running?

前端 未结 2 1212
我寻月下人不归
我寻月下人不归 2021-01-27 15:12

Im trying to detect when the module actually connects to my wifi AP, since .connect does not have a callback im doing something simple like this:

wifi.sta.config         


        
相关标签:
2条回答
  • 2021-01-27 15:50

    If you use a recent dev firmware you can do something really event based :

    wifi.setmode(wifi.STATION)
    wifi.sta.config(SSID, PASSWORD)
    
    function Success()
        tmr.stop(0)
        if (SERIAL_PRINT) then
            print("IP: " .. wifi.sta.getip())
        end
        wifi.sta.eventMonStop()
        wifi.sta.eventMonReg(wifi.STA_GOTIP, "unreg")
        dofile("mainProgram.lua")
    end
    
    function Failure()
        if (SERIAL_PRINT) then
            print("Unable to connect")
        end
        wifi.sta.eventMonStop()
        wifi.sta.eventMonReg(wifi.STA_GOTIP, "unreg")
        return 0
    end
    
    tmr.alarm(0,30000,0, function() Failure() end)
    wifi.sta.connect()
    wifi.sta.eventMonReg(wifi.STA_GOTIP, function() Success() end)
    wifi.sta.eventMonStart()
    

    EDIT: Please have a look to the documentation for a list of all events. If you wish to use this code, you'll have to handle the failure more cleanly.

    0 讨论(0)
  • 2021-01-27 15:51

    Using tmr.delay doesnot let run the event loop, you should use a timer callback.

    Then the code could be something like :

    wifi.sta.config("SSID","password")
    wifi.sta.connect()
    
    i=0
    tmr.alarm(1, 1000, 1, function()
        if (wifi.sta.status() ~= 5 and i < 10) then
           print("Status:"..wifi.sta.status())
           i = i + 1
        else
           tmr.stop(1)
           if (wifi.sta.status() == 5) then
              print("IP:"..wifi.sta.getip())
           else
              print("Status:"..wifi.sta.status())
           end
        end
    end)
    
    0 讨论(0)
提交回复
热议问题