Ardupilot2/libraries/AP_Baro/AP_Baro_BMP085_hil.cpp

70 lines
1.3 KiB
C++
Raw Normal View History

2011-10-13 11:22:03 -03:00
extern "C" {
// AVR LibC Includes
#include <inttypes.h>
#include <avr/interrupt.h>
#include "WConstants.h"
}
#include "AP_Baro_BMP085_hil.h"
2011-10-13 11:22:03 -03:00
// Constructors ////////////////////////////////////////////////////////////////
AP_Baro_BMP085_HIL::AP_Baro_BMP085_HIL()
2011-10-13 11:22:03 -03:00
{
}
// Public Methods //////////////////////////////////////////////////////////////
2011-12-11 00:30:24 -04:00
void AP_Baro_BMP085_HIL::init(AP_PeriodicProcess * scheduler)
2011-10-13 11:22:03 -03:00
{
BMP085_State=1;
}
// Read the sensor. This is a state machine
// We read one time Temperature (state = 1) and then 4 times Pressure (states 2-5)
2011-12-11 00:30:24 -04:00
uint8_t AP_Baro_BMP085_HIL::read()
2011-10-13 11:22:03 -03:00
{
uint8_t result = 0;
if (BMP085_State == 1){
BMP085_State++;
}else{
if (BMP085_State == 5){
BMP085_State = 1; // Start again from state = 1
result = 1; // New pressure reading
}else{
BMP085_State++;
result = 1; // New pressure reading
}
}
return(result);
}
void AP_Baro_BMP085_HIL::setHIL(float _Temp, float _Press)
2011-10-13 11:22:03 -03:00
{
// TODO: map floats to raw
Temp = _Temp;
Press = _Press;
}
2011-12-11 00:30:24 -04:00
int32_t AP_Baro_BMP085_HIL::get_pressure() {
return Press;
}
int16_t AP_Baro_BMP085_HIL::get_temperature() {
return Temp;
}
float AP_Baro_BMP085_HIL::get_altitude() {
return 0.0; // TODO
}
int32_t AP_Baro_BMP085_HIL::get_raw_pressure() {
return Press;
}
int32_t AP_Baro_BMP085_HIL::get_raw_temp() {
return Temp;
}