Wordclock/main.lua

194 lines
5.9 KiB
Lua
Raw Normal View History

-- Main Module
2016-06-19 00:30:09 +02:00
2021-01-31 20:22:32 +01:00
local looptimer = tmr.create()
displayword = {}
2021-02-09 19:58:59 +01:00
rowbgColor= {}
2016-06-19 00:08:21 +02:00
function syncTimeFromInternet()
2020-12-08 21:51:14 +01:00
if (syncRunning == nil) then
syncRunning=true
2016-06-19 00:08:21 +02:00
sntp.sync(sntpserverhostname,
function(sec,usec,server)
print('sync', sec, usec, server)
2020-12-08 21:51:14 +01:00
syncRunning=nil
2016-06-19 00:08:21 +02:00
end,
function()
print('failed!')
2020-12-08 21:51:14 +01:00
syncRunning=nil
2016-06-19 00:08:21 +02:00
end
)
2020-12-08 21:51:14 +01:00
end
2016-06-19 00:08:21 +02:00
end
2020-12-07 21:26:02 +01:00
function displayTime()
2021-02-09 20:18:24 +01:00
collectgarbage()
2019-04-27 18:34:57 +02:00
local sec, usec = rtctime.get()
2016-12-30 14:16:19 +01:00
-- Handle lazy programmer:
if (timezoneoffset == nil) then
timezoneoffset=0
end
2019-04-27 18:34:57 +02:00
local time = getTime(sec, timezoneoffset)
local words = display_timestat(time.hour, time.minute)
if ((dim ~= nil) and (dim == "on")) then
2021-02-10 20:04:22 +01:00
words.briPer=briPer
if (words.briPer ~= nil and words.briPer < 3) then
words.briPer=3
2020-12-08 20:30:43 +01:00
end
else
2021-02-10 20:04:22 +01:00
words.briPer=nil
end
2021-02-09 19:58:59 +01:00
mydofile("displayword")
if (displayword ~= nil) then
2019-05-11 12:28:23 +02:00
--if lines 4 to 6 are inverted due to hardware-fuckup, unfuck it here
local invertRows=false
if ((inv46 ~= nil) and (inv46 == "on")) then
invertRows=true
end
local characters = displayword.countChars(words)
2021-01-23 19:17:30 +01:00
ledBuf = displayword.generateLEDs(words, colorBg, color, color1, color2, color3, color4, invertRows, characters)
2019-05-03 20:19:12 +02:00
end
displayword = nil
2019-05-03 20:19:12 +02:00
if (ledBuf ~= nil) then
2019-05-11 12:28:23 +02:00
ws2812.write(ledBuf)
else
-- set FG to fix value: RED
local space=string.char(0,0,0)
local color = string.char(255,0,0)
ws2812.write(space:rep(107) .. color:rep(3)) -- UHR
end
-- cleanup
2021-02-10 20:04:22 +01:00
briPer=words.briPer
words=nil
time=nil
collectgarbage()
end
2016-06-19 00:30:09 +02:00
function normalOperation()
2016-06-19 22:48:44 +02:00
-- use default color, if nothing is defined
if (color == nil) then
-- Color is defined as GREEN, RED, BLUE
color=string.char(0,0,250)
end
2019-05-22 21:25:33 +02:00
print("Fg Color: " .. tostring(string.byte(color,1)) .. "x" .. tostring(string.byte(color,2)) .. "x" .. tostring(string.byte(color,3)) )
2016-06-19 00:30:09 +02:00
2021-02-10 19:45:28 +01:00
local connect_counter=0
2016-06-19 00:30:09 +02:00
-- Wait to be connect to the WiFi access point.
2021-01-31 20:22:32 +01:00
local wifitimer = tmr.create()
wifitimer:register(5000, tmr.ALARM_SINGLE, function (t)
2016-06-19 00:30:09 +02:00
connect_counter=connect_counter+1
if wifi.sta.status() ~= 5 then
2016-06-19 17:48:39 +02:00
print(connect_counter .. "/60 Connecting to AP...")
2019-05-03 23:18:27 +02:00
if (connect_counter % 5 ~= 4) then
2017-03-01 19:53:55 +01:00
local wlanColor=string.char((connect_counter % 6)*20,(connect_counter % 5)*20,(connect_counter % 3)*20)
local space=string.char(0,0,0)
2019-05-03 23:18:27 +02:00
local buf=space:rep(6)
if ((connect_counter % 5) >= 1) then
buf = buf .. wlanColor
else
buf = buf .. space
end
buf = buf .. space:rep(4)
buf= buf .. space:rep(3)
if ((connect_counter % 5) >= 3) then
buf = buf .. wlanColor
else
buf = buf .. space
end
if ((connect_counter % 5) >= 2) then
buf = buf .. wlanColor
else
buf = buf .. space
end
if ((connect_counter % 5) >= 0) then
buf = buf .. wlanColor
else
buf = buf .. space
end
buf = buf .. space:rep(100)
2017-03-01 19:53:55 +01:00
ws2812.write(buf)
2016-06-19 00:30:09 +02:00
else
ws2812.write(string.char(0,0,0):rep(114))
2016-06-19 00:30:09 +02:00
end
else
2021-01-31 20:22:32 +01:00
t:unregister()
2016-06-19 00:30:09 +02:00
print('IP: ',wifi.sta.getip())
2016-06-19 17:48:39 +02:00
-- Here the WLAN is found, and something is done
print("Solving dependencies")
2021-01-15 18:02:17 +01:00
local dependModules = { "timecore" , "wordclock", "mqtt" }
2016-06-19 17:48:39 +02:00
for _,mod in pairs(dependModules) do
print("Loading " .. mod)
mydofile(mod)
end
2020-12-08 21:51:14 +01:00
2021-01-31 20:22:32 +01:00
local setupCounter=5
local alive=0
2021-02-09 20:18:24 +01:00
looptimer:register(2500, tmr.ALARM_AUTO, function (lt)
2020-12-08 21:51:14 +01:00
if (setupCounter > 4) then
syncTimeFromInternet()
setupCounter=setupCounter-1
2021-02-09 20:07:21 +01:00
alive = 1
2020-12-08 21:51:14 +01:00
elseif (setupCounter > 3) then
2021-01-15 18:02:17 +01:00
if (startMqttClient ~= nil) then
startMqttClient()
2020-12-08 21:51:14 +01:00
else
2021-01-15 18:02:17 +01:00
print("NO Mqtt found")
mydofile("telnet")
2020-12-08 21:51:14 +01:00
end
setupCounter=setupCounter-1
elseif (setupCounter > 2) then
2021-01-15 18:02:17 +01:00
if (startTelnetServer ~= nil) then
startTelnetServer()
2020-12-08 21:51:14 +01:00
else
2021-01-15 18:14:39 +01:00
displayTime()
2020-12-08 21:51:14 +01:00
end
setupCounter=setupCounter-1
2021-02-09 20:18:24 +01:00
elseif ( (alive % 120) == 0) then
2021-02-09 20:07:21 +01:00
-- sync the time every 5 minutes
2021-01-31 20:22:32 +01:00
syncTimeFromInternet()
2021-02-09 20:07:21 +01:00
alive = alive + 1
2020-12-08 21:51:14 +01:00
else
displayTime()
2021-02-09 20:07:21 +01:00
alive = alive + 1
2020-12-08 21:51:14 +01:00
end
collectgarbage()
2021-02-09 20:07:21 +01:00
-- Feed the system watchdog.
tmr.wdclr()
2020-12-08 21:51:14 +01:00
end)
2021-01-31 20:22:32 +01:00
looptimer:start()
2016-06-19 00:30:09 +02:00
end
-- when no wifi available, open an accesspoint and ask the user
2016-06-19 17:48:39 +02:00
if (connect_counter >= 60) then -- 300 is 30 sec in 100ms cycle
startSetupMode()
2016-06-19 00:30:09 +02:00
end
end)
2021-01-31 20:22:32 +01:00
wifitimer:start()
2020-12-08 20:45:28 +01:00
end
-------------------main program -----------------------------
2021-02-10 20:04:22 +01:00
briPer = 50 -- Default brightness is set to 50%
ws2812.init() -- WS2812 LEDs initialized on GPIO2
2016-05-04 23:23:49 +02:00
2019-04-19 22:05:00 +02:00
----------- button ---------
gpio.mode(3, gpio.INPUT)
2021-01-31 20:22:32 +01:00
local btnCounter=0
-- Start the time Thread handling the button
local btntimer = tmr.create()
btntimer:register(5000, tmr.ALARM_AUTO, function (t)
2019-04-19 22:05:00 +02:00
if (gpio.read(3) == 0) then
2021-01-31 20:22:32 +01:00
looptimer:unregister()
2019-04-19 22:05:00 +02:00
print("Button pressed " .. tostring(btnCounter))
btnCounter = btnCounter + 5
local ledBuf= string.char(128,0,0):rep(btnCounter) .. string.char(0,0,0):rep(110 - btnCounter)
ws2812.write(ledBuf)
if (btnCounter >= 110) then
file.remove("config.lua")
2020-12-08 21:51:14 +01:00
file.remove("config.lc")
2019-04-19 22:05:00 +02:00
node.restart()
end
end
end)
2021-01-31 20:22:32 +01:00
btntimer:start()