blob: 01ccf7728cc49015993cb6783741fa11c7f2729f (
plain)
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
|
/**
* @file SensorHandler.h
* @brief Reads on board sensors... acceleration, pressure, light and temperture.
* @author Leon Lindenfelser
* @version 1.0
*
*/
#ifndef SENSORHANDLER_H
#define SENSORHANDLER_H
#include "mbed.h"
#include "MMA845x.h"
#include "MPL3115A2.h"
#include "ISL29011.h"
#include "DOGS102.h"
#include "rtos.h"
#include <string>
#include <vector>
#define START_THREAD 1
class SensorHandler
{
public:
enum Scale{CELSIUS, FAHRENHEIT};
SensorHandler(void);
~SensorHandler(void);
MMA845x_DATA getAcceleration(void);
float getLight(void);
uint16_t getLightRaw(void);
float getPressure(void);
uint32_t getPressureRaw(void);
float getTemp(Scale);
float getAltitude(void);
MPL3115A2_DATA getBarometer(void);
private:
Thread _getSensorThread;
static void startSensorThread (void const *p);
void readSensors(void);
void initSensors(void);
I2C _mDoti2c;
MMA845x _accelerometer;
MPL3115A2 _barometricSensor;
ISL29011 _lightSensor;
MMA845x_DATA _accelerometerData;
MPL3115A2_DATA _barometerData;
uint16_t _light;
uint32_t _pressure;
Mutex _mutex;
};
#endif //SENSORHANDLER_H
|