application.cpp 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  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;
  13. // Sensors values
  14. float SensorT, SensorH, SensorHI, SensorCR;
  15. String StrCF;
  16. // Time values
  17. time_t Time, NTPLastUpdate;
  18. void
  19. process ();
  20. void
  21. connectOk ();
  22. void
  23. connectFail ();
  24. void
  25. showTime ();
  26. // NTP Client
  27. void
  28. onNtpReceive (NtpClient& client, time_t timestamp);
  29. NtpClient ntpClient ("ntps1-0.cs.tu-berlin.de", 300, onNtpReceive);
  30. void
  31. 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. //wait for sensor startup
  39. delay (1000);
  40. // DHT sensor start
  41. dht.begin ();
  42. // 7-segment output
  43. MAX7219_Init ();
  44. // set timezone hourly difference to UTC
  45. SystemClock.setTimeZone (ActiveConfig.AddTZ);
  46. WifiStation.config (ActiveConfig.NetworkSSID, ActiveConfig.NetworkPassword);
  47. WifiStation.enable (true);
  48. WifiAccessPoint.enable (false);
  49. WifiStation.waitConnection (connectOk, 20, connectFail); // We recommend 20+ seconds for connection timeout at start
  50. // раз в минуту?
  51. procTimer.initializeMs (60000, process).start ();
  52. process ();
  53. // обновление экрана два раза в секунду
  54. displayTimer.initializeMs (500, showTime).start ();
  55. }
  56. void
  57. showTime ()
  58. {
  59. static int8_t oldHour, oldMinute, pos = 1;
  60. static time_t oldTime;
  61. DateTime dt;
  62. Time = SystemClock.now ();
  63. dt.setTime (Time);
  64. /*
  65. * теперь в dt у нас следующее:
  66. * int8_t Hour;
  67. * int8_t Minute;
  68. * int8_t Second;
  69. * int16_t Milliseconds;
  70. * int8_t Day;
  71. * int8_t DayofWeek; -- Sunday is day 0
  72. * int8_t Month; // Jan is month 0
  73. * int16_t Year; // Full Year numer
  74. */
  75. int8_t si = dt.Second / 5;
  76. if (oldTime != Time)
  77. {
  78. oldTime = Time;
  79. if (pos > 8)
  80. {
  81. pos = 1;
  82. }
  83. MAX7219_writeData (pos, pos);
  84. pos++;
  85. /*
  86. switch (si)
  87. {
  88. case 0:
  89. case 2:
  90. case 4:
  91. case 6:
  92. case 8:
  93. case 10:
  94. MAX7219_writeData(MAX7219_DIGIT5, (int)(SensorT)/10);
  95. MAX7219_writeData(MAX7219_DIGIT6, (int)(SensorT)%10);
  96. MAX7219_writeData(MAX7219_DIGIT7, SYM_Temp);
  97. break;
  98. case 1:
  99. case 3:
  100. case 7:
  101. case 9:
  102. MAX7219_writeData(MAX7219_DIGIT5, (int)(SensorH)/10);
  103. MAX7219_writeData(MAX7219_DIGIT6, (int)(SensorH)%10);
  104. MAX7219_writeData(MAX7219_DIGIT7, SYM_H);
  105. break;
  106. case 5:
  107. case 11:
  108. MAX7219_writeData(MAX7219_DIGIT5, SYM_BLANK);
  109. MAX7219_writeData(MAX7219_DIGIT6, dt.DayofWeek/10);
  110. MAX7219_writeData(MAX7219_DIGIT7, dt.DayofWeek%10);
  111. break;
  112. }
  113. */
  114. /*
  115. if (oldMinute != dt.Minute)
  116. {
  117. oldMinute = dt.Minute;
  118. if (oldHour != dt.Hour)
  119. {
  120. oldHour = dt.Hour;
  121. }
  122. }
  123. if (si != 5 || si != 11)
  124. {
  125. MAX7219_writeData(MAX7219_DIGIT0, dt.Hour/10);
  126. MAX7219_writeData(MAX7219_DIGIT1, dt.Hour%10);
  127. MAX7219_writeData(MAX7219_DIGIT2, SYM_Minus);
  128. MAX7219_writeData(MAX7219_DIGIT3, dt.Minute/10);
  129. MAX7219_writeData(MAX7219_DIGIT4, dt.Minute%10);
  130. }
  131. else if (si == 5 || si == 11)
  132. {
  133. MAX7219_writeData(MAX7219_DIGIT0, dt.Day/10);
  134. MAX7219_writeData(MAX7219_DIGIT1, dt.Day%10);
  135. MAX7219_writeData(MAX7219_DIGIT2, SYM_Minus);
  136. MAX7219_writeData(MAX7219_DIGIT3, dt.Month/10);
  137. MAX7219_writeData(MAX7219_DIGIT4, dt.Month%10);
  138. }
  139. */
  140. /*
  141. if ((si & 1) == 0)
  142. {
  143. MAX7219_writeData(MAX7219_DIGIT5, (int)(SensorT)/10);
  144. MAX7219_writeData(MAX7219_DIGIT6, (int)(SensorT)%10);
  145. MAX7219_writeData(MAX7219_DIGIT7, SYM_Temp);
  146. }
  147. else
  148. {
  149. MAX7219_writeData(MAX7219_DIGIT5, (int)(SensorH)/10);
  150. MAX7219_writeData(MAX7219_DIGIT6, (int)(SensorH)%10);
  151. MAX7219_writeData(MAX7219_DIGIT7, SYM_H);
  152. }
  153. */
  154. }
  155. /*
  156. else // time the same, output blank for "hh mm"
  157. {
  158. if (si != 5 || si != 11)
  159. {
  160. MAX7219_writeData(MAX7219_DIGIT2, SYM_BLANK );
  161. }
  162. }
  163. */
  164. }
  165. /*
  166. * Читаем данные с DHT22, в случае неудачи -- данные остануться старыми.
  167. * меня это полностью устраивает.
  168. */
  169. void
  170. process ()
  171. {
  172. TempAndHumidity th;
  173. ComfortState cf;
  174. static int8_t status;
  175. if (dht.readTempAndHumidity (th))
  176. {
  177. status = 0;
  178. SensorT = th.temp;
  179. SensorH = th.humid;
  180. SensorHI = dht.getHeatIndex ();
  181. SensorCR = dht.getComfortRatio (cf);
  182. switch (cf)
  183. {
  184. case Comfort_OK:
  185. StrCF = "OK";
  186. break;
  187. case Comfort_TooHot:
  188. StrCF = "Too Hot";
  189. break;
  190. case Comfort_TooCold:
  191. StrCF = "Too Cold";
  192. break;
  193. case Comfort_TooDry:
  194. StrCF = "Too Dry";
  195. break;
  196. case Comfort_TooHumid:
  197. StrCF = "Too Humid";
  198. break;
  199. case Comfort_HotAndHumid:
  200. StrCF = "Hot And Humid";
  201. break;
  202. case Comfort_HotAndDry:
  203. StrCF = "Hot And Dry";
  204. break;
  205. case Comfort_ColdAndHumid:
  206. StrCF = "Cold And Humid";
  207. break;
  208. case Comfort_ColdAndDry:
  209. StrCF = "Cold And Dry";
  210. break;
  211. default:
  212. StrCF = "Unknown";
  213. break;
  214. }
  215. }
  216. else
  217. {
  218. /*
  219. * В случае, если от датчика ничего не получили, запустим повторный опрос через
  220. * 10 секунд, но не более 5 раз подряд.
  221. */
  222. if (status < 6)
  223. {
  224. status++;
  225. procRTimer.initializeMs (10000, process).startOnce ();
  226. }
  227. }
  228. }
  229. void
  230. connectOk ()
  231. {
  232. WifiAccessPoint.enable (false);
  233. Serial.print ("I'm connecteed. IP: ");
  234. Serial.println (WifiStation.getIP ().toString ());
  235. startWebServer ();
  236. }
  237. /*
  238. * в случае неудачи подключения поднимаем точку доступа без авторизации
  239. */
  240. void
  241. connectFail ()
  242. {
  243. WifiAccessPoint.config ("MeteoConfig", "", AUTH_OPEN);
  244. WifiAccessPoint.enable (true);
  245. // Stop main screen output
  246. procTimer.stop ();
  247. displayTimer.stop ();
  248. Serial.println ("WiFi MeteoConfig");
  249. Serial.println (WifiAccessPoint.getIP ());
  250. startWebServer ();
  251. WifiStation.waitConnection (connectOk); // Wait connection
  252. }
  253. /*
  254. * NTP Client
  255. */
  256. void
  257. onNtpReceive (NtpClient& client, time_t timestamp)
  258. {
  259. SystemClock.setTime (timestamp, eTZ_UTC);
  260. NTPLastUpdate = SystemClock.now ();
  261. Serial.println ("*** Time synchronized OK! ***"); // DEBUG
  262. }