application.cpp 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355
  1. #include <user_config.h>
  2. #include <SmingCore/SmingCore.h>
  3. #include <Libraries/DHT/DHT.h>
  4. ///////////////////////////////////////////////////////////////////
  5. // Set your SSID & Pass for initial configuration
  6. #include "../include/configuration.h" // application configuration
  7. ///////////////////////////////////////////////////////////////////
  8. #include "max7219.h"
  9. #include "webserver.h"
  10. DHT dht(DHT_PIN, DHT22);
  11. Timer procTimer, procRTimer;
  12. Timer displayTimer, tmpTimer;
  13. Timer showHighTimer, showLowTimer;
  14. // Sensors values
  15. float SensorT, SensorH, SensorHI, SensorCR;
  16. String StrCF;
  17. // Time values
  18. time_t Time, NTPLastUpdate;
  19. DateTime dt;
  20. void process(void);
  21. void connectOk(void);
  22. void connectFail(void);
  23. void showWatch(void);
  24. void showTime(void);
  25. void showTemperature(void);
  26. void showHumidity(void);
  27. // NTP Client
  28. void
  29. onNtpReceive(NtpClient& client, time_t timestamp);
  30. NtpClient ntpClient("ntps1-0.cs.tu-berlin.de", 300, onNtpReceive);
  31. void init()
  32. {
  33. spiffs_mount(); // Mount file system, in order to work with files
  34. Serial.begin(SERIAL_BAUD_RATE); // 115200 by default
  35. Serial.systemDebugOutput(false); // Debug output to serial
  36. Serial.println("Wall Segment Clock");
  37. ActiveConfig = loadConfig();
  38. // set timezone hourly difference to UTC
  39. SystemClock.setTimeZone(ActiveConfig.AddTZ);
  40. WifiStation.config(ActiveConfig.NetworkSSID, ActiveConfig.NetworkPassword);
  41. WifiStation.enable(true);
  42. WifiAccessPoint.enable(false);
  43. WifiStation.waitConnection(connectOk, 20, connectFail); // We recommend 20+ seconds for connection timeout at start
  44. // DHT sensor start
  45. dht.begin();
  46. // опрос датчиков -- раз в минуту?
  47. procTimer.initializeMs(60000, process).start();
  48. process();
  49. // 7-segment output
  50. MAX7219_Init();
  51. tmpTimer.initializeMs(10, MAX7219_FillMinus).startOnce();
  52. // обновление экрана два раза в секунду
  53. displayTimer.initializeMs(500, showWatch).start();
  54. }
  55. void showWatch()
  56. {
  57. static uint8_t oldHour, oldMinute, old_si;
  58. static time_t oldTime;
  59. Time = SystemClock.now();
  60. dt.setTime(Time);
  61. /*
  62. * теперь в dt у нас следующее:
  63. * int8_t Hour;
  64. * int8_t Minute;
  65. * int8_t Second;
  66. * int16_t Milliseconds;
  67. * int8_t Day;
  68. * int8_t DayofWeek; -- Sunday is day 0
  69. * int8_t Month; // Jan is month 0
  70. * int16_t Year; // Full Year numer
  71. */
  72. uint8_t si = dt.Second / 5;
  73. /*
  74. * 0 - Temp
  75. * 1 - Humidity
  76. * 2 - Temp
  77. * 3 - Humidity
  78. * 4 - Temp
  79. * 5 - Humidity
  80. * 6 - Temp
  81. * 7 - Humidity
  82. * 8 - Temp
  83. * 9 - Humidity
  84. * 10 - Temp
  85. * 11 - Humidity
  86. */
  87. if (oldTime == Time)
  88. {
  89. // time the same, output blank for [HH MM]
  90. if (si != 5 || si != 11)
  91. {
  92. MAX7219_writeData(MAX7219_DIGIT2, SYM_BLANK);
  93. }
  94. }
  95. else
  96. {
  97. oldTime = Time;
  98. if (oldMinute != dt.Minute)
  99. {
  100. oldMinute = dt.Minute;
  101. MAX7219_writeData(MAX7219_DIGIT3, dt.Minute / 10);
  102. MAX7219_writeData(MAX7219_DIGIT4, dt.Minute % 10);
  103. if (oldHour != dt.Hour)
  104. {
  105. oldHour = dt.Hour;
  106. MAX7219_writeData(MAX7219_DIGIT0, dt.Hour / 10);
  107. MAX7219_writeData(MAX7219_DIGIT1, dt.Hour % 10);
  108. }
  109. }
  110. switch(dt.Second / 15)
  111. {
  112. case 0:
  113. MAX7219_writeData(MAX7219_DIGIT2, SYM_Minus);
  114. break;
  115. case 1:
  116. MAX7219_writeData(MAX7219_DIGIT2, SYM_Minus2L);
  117. break;
  118. case 2:
  119. MAX7219_writeData(MAX7219_DIGIT2, SYM_Minus2H);
  120. break;
  121. case 3:
  122. MAX7219_writeData(MAX7219_DIGIT2, SYM_Minus3);
  123. break;
  124. }
  125. if (old_si != si)
  126. {
  127. old_si = si;
  128. switch (si)
  129. {
  130. case 0:
  131. showLowTimer.initializeMs(10, showTemperature).startOnce();
  132. break;
  133. case 1:
  134. showLowTimer.initializeMs(10, showHumidity).startOnce();
  135. break;
  136. case 2:
  137. showLowTimer.initializeMs(10, showTemperature).startOnce();
  138. break;
  139. case 3:
  140. showLowTimer.initializeMs(10, showHumidity).startOnce();
  141. break;
  142. case 4:
  143. showLowTimer.initializeMs(10, showTemperature).startOnce();
  144. break;
  145. case 5:
  146. showLowTimer.initializeMs(10, showHumidity).startOnce();
  147. break;
  148. case 6:
  149. showLowTimer.initializeMs(10, showTemperature).startOnce();
  150. break;
  151. case 7:
  152. showLowTimer.initializeMs(10, showHumidity).startOnce();
  153. break;
  154. case 8:
  155. showLowTimer.initializeMs(10, showTemperature).startOnce();
  156. break;
  157. case 9:
  158. showLowTimer.initializeMs(10, showHumidity).startOnce();
  159. break;
  160. case 10:
  161. showLowTimer.initializeMs(10, showTemperature).startOnce();
  162. break;
  163. case 11:
  164. showLowTimer.initializeMs(10, showHumidity).startOnce();
  165. break;
  166. }
  167. }
  168. }
  169. }
  170. /*
  171. * Выводим текущее время [HH MM] на верхние индикаторы
  172. */
  173. void showTime(void)
  174. {
  175. // уберём ведущий ноль у часов
  176. if (dt.Hour >= 9)
  177. {
  178. MAX7219_writeData(MAX7219_DIGIT0, dt.Hour / 10);
  179. }
  180. else
  181. {
  182. MAX7219_writeData(MAX7219_DIGIT0, MAX7219_CHAR_BLANK);
  183. }
  184. MAX7219_writeData(MAX7219_DIGIT1, dt.Hour % 10);
  185. MAX7219_writeData(MAX7219_DIGIT3, dt.Minute / 10);
  186. MAX7219_writeData(MAX7219_DIGIT4, dt.Minute % 10);
  187. }
  188. /*
  189. * Выводим температуру на нижние индикаторы
  190. */
  191. void showTemperature(void)
  192. {
  193. MAX7219_writeData(MAX7219_DIGIT5, SYM_Temp);
  194. MAX7219_writeData(MAX7219_DIGIT6, (int) (SensorT) / 10);
  195. MAX7219_writeData(MAX7219_DIGIT7, (int) (SensorT) % 10);
  196. }
  197. /*
  198. * Выводим влажность на нижние индикаторы
  199. */
  200. void showHumidity(void)
  201. {
  202. MAX7219_writeData(MAX7219_DIGIT5, SYM_H);
  203. MAX7219_writeData(MAX7219_DIGIT6, (int) (SensorH) / 10);
  204. MAX7219_writeData(MAX7219_DIGIT7, (int) (SensorH) % 10);
  205. }
  206. /*
  207. * Выводим дату на верхние индикаторы [DD MM]
  208. */
  209. /*
  210. void showDate(void)
  211. {
  212. MAX7219_writeData(MAX7219_DIGIT0, dt.Day/10);
  213. MAX7219_writeData(MAX7219_DIGIT1, dt.Day%10);
  214. MAX7219_writeData(MAX7219_DIGIT2, SYM_Minus);
  215. MAX7219_writeData(MAX7219_DIGIT3, dt.Month/10);
  216. MAX7219_writeData(MAX7219_DIGIT4, dt.Month%10);
  217. MAX7219_writeData(MAX7219_DIGIT6, (uint8_t)(dt.DayofWeek / 10));
  218. MAX7219_writeData(MAX7219_DIGIT7, (uint8_t)(dt.DayofWeek % 10));
  219. }
  220. */
  221. /*
  222. * Читаем данные с DHT22, в случае неудачи -- данные остануться старыми.
  223. * меня это полностью устраивает.
  224. */
  225. void process()
  226. {
  227. TempAndHumidity th;
  228. ComfortState cf;
  229. static int8_t status;
  230. if (dht.readTempAndHumidity(th))
  231. {
  232. status = 0;
  233. SensorT = th.temp;
  234. SensorH = th.humid;
  235. SensorHI = dht.getHeatIndex();
  236. SensorCR = dht.getComfortRatio(cf);
  237. switch (cf)
  238. {
  239. case Comfort_OK:
  240. StrCF = "OK";
  241. break;
  242. case Comfort_TooHot:
  243. StrCF = "Too Hot";
  244. break;
  245. case Comfort_TooCold:
  246. StrCF = "Too Cold";
  247. break;
  248. case Comfort_TooDry:
  249. StrCF = "Too Dry";
  250. break;
  251. case Comfort_TooHumid:
  252. StrCF = "Too Humid";
  253. break;
  254. case Comfort_HotAndHumid:
  255. StrCF = "Hot And Humid";
  256. break;
  257. case Comfort_HotAndDry:
  258. StrCF = "Hot And Dry";
  259. break;
  260. case Comfort_ColdAndHumid:
  261. StrCF = "Cold And Humid";
  262. break;
  263. case Comfort_ColdAndDry:
  264. StrCF = "Cold And Dry";
  265. break;
  266. default:
  267. StrCF = "Unknown";
  268. break;
  269. }
  270. }
  271. else
  272. {
  273. /*
  274. * В случае, если от датчика ничего не получили, запустим повторный опрос через
  275. * 10 секунд, но не более 5 раз подряд.
  276. */
  277. if (status < 6)
  278. {
  279. status++;
  280. procRTimer.initializeMs(10000, process).startOnce();
  281. }
  282. }
  283. }
  284. void connectOk()
  285. {
  286. WifiAccessPoint.enable(false);
  287. Serial.print("I'm connecteed. IP: ");
  288. Serial.println(WifiStation.getIP().toString());
  289. startWebServer();
  290. }
  291. /*
  292. * в случае неудачи подключения поднимаем точку доступа без авторизации
  293. */
  294. void connectFail()
  295. {
  296. WifiAccessPoint.config("MeteoConfig", "", AUTH_OPEN);
  297. WifiAccessPoint.enable(true);
  298. // Stop main screen output
  299. procTimer.stop();
  300. displayTimer.stop();
  301. Serial.println("WiFi MeteoConfig");
  302. Serial.println(WifiAccessPoint.getIP());
  303. startWebServer();
  304. WifiStation.waitConnection(connectOk); // Wait connection
  305. }
  306. /*
  307. * NTP Client
  308. */
  309. void onNtpReceive(NtpClient& client, time_t timestamp)
  310. {
  311. SystemClock.setTime(timestamp, eTZ_UTC);
  312. NTPLastUpdate = SystemClock.now();
  313. Serial.println("*** Time synchronized OK! ***"); // DEBUG
  314. }