A low cost DIY sound pressure level sensor for enabling environmental noise awareness. https://lukasschwarz.org/noise-sensor
Non puoi selezionare più di 25 argomenti Gli argomenti devono iniziare con una lettera o un numero, possono includere trattini ('-') e possono essere lunghi fino a 35 caratteri.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. // vim: noai:sw=2:tw=88
  2. #include "I2C_DMAC.h"
  3. #include "NoiseSensorNode.h"
  4. //#include <NTPClient.h>
  5. #include <WiFiUdp.h>
  6. #define LORA_HEADER_LENGTH 2
  7. #define BATTERY_FIELD_SIZE 1
  8. #define PACKET_COUNT 5
  9. class NoiseSensorClass {
  10. private:
  11. //NTPClient* _time_client;
  12. uint32_t _last_sync_time;
  13. uint8_t _tick_count = 20;
  14. uint8_t _tick_duration = 2; // in seconds
  15. uint8_t _tx_offset = 1;
  16. uint8_t _i2c_address = 0x3C;
  17. bool _first_sync = true;
  18. // These aren't _real_ const but they shouldn't be redefined nonetheless.
  19. uint16_t _PACKET_SIZE;
  20. uint16_t _REQUEST_SIZE;
  21. NoiseSensorNode* _nodes[];
  22. uint8_t getDeviceID();
  23. bool setupNTPClient();
  24. public:
  25. /**
  26. * Begin the measurement cycle by sending a sync message.
  27. *
  28. * @return true on success, false on failure
  29. */
  30. bool begin();
  31. /**
  32. * Call begin() with a custom tick count.
  33. *
  34. * @return true on success, false on failure
  35. */
  36. bool begin(uint8_t tick_count);
  37. /**
  38. * Call begin() with a custom tick count and tick duration.
  39. *
  40. * @return true on success, false on failure
  41. */
  42. bool begin(uint8_t tick_count, uint8_t tick_duration);
  43. /**
  44. * Call begin() with a custom tick count, tick duration and tx_offset.
  45. *
  46. * @return true on success, false on failure
  47. */
  48. bool begin(uint8_t tick_count, uint8_t tick_duration, uint8_t tx_offset);
  49. void setIds(const char* sensebox_ids[], const char* sensor_ids[]);
  50. String buildHTTPHeader(uint8_t device_id, const char* server, uint16_t content_length);
  51. bool beaconReady();
  52. bool requestReady();
  53. /**
  54. * Read the newly available data from the slave.
  55. *
  56. * @return true on success, false on failure
  57. */
  58. bool read();
  59. /**
  60. * Print the measurements in a pretty format.
  61. */
  62. void printMeasurements(uint8_t device_id);
  63. /**
  64. * Send the sync message to the slave.
  65. *
  66. * @return true on success, false on failure
  67. */
  68. bool sendSyncBeacon();
  69. String buildSenseBoxJSON(uint8_t device_id);
  70. };
  71. extern NoiseSensorClass NoiseSensor;