-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSensorCollection.cpp
More file actions
68 lines (61 loc) · 1.65 KB
/
SensorCollection.cpp
File metadata and controls
68 lines (61 loc) · 1.65 KB
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
#include "SensorCollection.h"
SensorCollection::SensorCollection(uint8_t size, uint8_t lpp_size) : _maxsize(size), _lpp(lpp_size)
{
_sensorIds = (int32_t *)malloc(size * sizeof(int32_t));
_sensors = (Adafruit_Sensor **)malloc(size * sizeof(Adafruit_Sensor *));
};
void SensorCollection::addSensor(Adafruit_Sensor *sensor, int32_t sensor_id)
{
if (_cursor < _maxsize)
{
if (sensor_id > 0)
{
_sensorIds[_cursor] = sensor_id;
}
else
{
sensor_t sensor_details;
sensor->getSensor(&sensor_details);
_sensorIds[_cursor] = sensor_details.sensor_id;
}
_sensors[_cursor] = sensor;
_cursor += 1;
}
}
CayenneLPP *SensorCollection::update()
{
_lpp.reset();
for (uint8_t i = 0; i < _cursor; i += 1)
{
_sensors[i]->getEvent(&_event);
switch (_event.type)
{
case SENSOR_TYPE_VOLTAGE:
{
_lpp.addAnalogInput(_sensorIds[i], _event.voltage);
break;
}
case SENSOR_TYPE_PROXIMITY:
{
_lpp.addAnalogInput(_sensorIds[i], _event.distance);
break;
}
case SENSOR_TYPE_AMBIENT_TEMPERATURE:
{
_lpp.addTemperature(_sensorIds[i], _event.temperature);
break;
}
case SENSOR_TYPE_RELATIVE_HUMIDITY:
{
_lpp.addRelativeHumidity(_sensorIds[i], _event.relative_humidity);
break;
}
case SENSOR_TYPE_PRESSURE:
{
_lpp.addBarometricPressure(_sensorIds[i], _event.pressure);
break;
}
}
}
return &_lpp;
}