-
Notifications
You must be signed in to change notification settings - Fork 0
/
hkdash_esp32.py
103 lines (83 loc) · 2.76 KB
/
hkdash_esp32.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#!/usr/bin/python
# -*- coding:utf-8 -*-
import time
from datetime import datetime
import locale
import logging
from data.nightscout import NightscoutData
from data.weather import WeatherData
from data.ephem import EphemData
from data.birthdays import BirthdayData
from data.sunspot_image import SunspotImage
from data.sunspot_number import SunspotNumber
from data.buienradar_text import BuienradarText
from data.kp_index import KpIndexData
from draw.hkdraw import HKDraw
from esp32_client import send_image
# from pixel.nightscout_pixel import draw_ns_pixel, turn_off_pixel
from dotenv import load_dotenv
load_dotenv()
logging.basicConfig(level=logging.ERROR)
logging.error(f"##### Application start at {datetime.now()} ######")
try:
locale.setlocale(locale.LC_TIME, "nl_NL.utf8")
logging.info("Starting")
width = 800
height = 480
logging.info("Init")
# Initialize data sources
dataSources = {
"nightscout": NightscoutData(),
"weather": WeatherData(),
"ephem": EphemData(),
"birthdays": BirthdayData(),
"sunspot_image": SunspotImage(),
"sunspot_number": SunspotNumber(),
"buienradar_text": BuienradarText(),
"kp_index": KpIndexData()
}
# Initialize drawing target
hkdraw = HKDraw(width, height)
isStandby = False
while True:
# Check if we should sleep
now = datetime.now()
if now.hour <= 6:
if not isStandby:
hkdraw.clear_image()
send_image(hkdraw.context.image)
#turn_off_pixel()
isStandby = True
else:
isStandby = False
if not isStandby:
# Retrieve data
data = {}
for key, source in dataSources.items():
logging.info("GET DATA for " + key)
try:
data[key] = source.get_data()
except Exception as err:
data[key] = { "error": str(err) }
# Save the data (for debugging)
# with open('debug_data.json', 'w') as outfile:
# json.dump(data, outfile)
# Draw
hkdraw.draw_data(data)
# Pixel
# if not "error" in data["nightscout"]:
# draw_ns_pixel(data["nightscout"])
# Display
logging.info("SEND IMAGE")
send_image(hkdraw.context.image)
# Sleep until the next update
now = datetime.now()
minutes_to_go = 4 - now.minute % 5
seconds_to_go = 60 - now.second + minutes_to_go * 60
logging.info(f"Sleeping for {seconds_to_go} seconds")
time.sleep(seconds_to_go)
except IOError as e:
logging.info(e)
except KeyboardInterrupt:
logging.info("ctrl + c:")
exit()