mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 02:18:29 -04:00
AnalogSource: return a float from read() method
this gives the full resolution when using the ADC backend. It also adds scaling for the Arduino backend
This commit is contained in:
parent
f6f808357c
commit
10e546eebd
@ -1,9 +1,9 @@
|
|||||||
|
|
||||||
#include "AP_AnalogSource_ADC.h"
|
#include "AP_AnalogSource_ADC.h"
|
||||||
|
|
||||||
int AP_AnalogSource_ADC::read(void)
|
float AP_AnalogSource_ADC::read(void)
|
||||||
{
|
{
|
||||||
int fullscale = _adc->Ch(_ch);
|
float fullscale = _adc->Ch(_ch);
|
||||||
int scaled = _prescale * fullscale;
|
float scaled = _prescale * fullscale;
|
||||||
return scaled;
|
return scaled;
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ class AP_AnalogSource_ADC : public AP_AnalogSource
|
|||||||
public:
|
public:
|
||||||
AP_AnalogSource_ADC( AP_ADC * adc, int ch, float prescale = 1.0 ) :
|
AP_AnalogSource_ADC( AP_ADC * adc, int ch, float prescale = 1.0 ) :
|
||||||
_adc(adc), _ch(ch), _prescale(prescale) {}
|
_adc(adc), _ch(ch), _prescale(prescale) {}
|
||||||
int read(void);
|
float read(void);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
AP_ADC * _adc;
|
AP_ADC * _adc;
|
||||||
|
@ -1,8 +1,11 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
#include "wiring.h"
|
#include "wiring.h"
|
||||||
#include "AP_AnalogSource_Arduino.h"
|
#include "AP_AnalogSource_Arduino.h"
|
||||||
|
|
||||||
int AP_AnalogSource_Arduino::read(void)
|
float AP_AnalogSource_Arduino::read(void)
|
||||||
{
|
{
|
||||||
return analogRead(_pin);
|
float fullscale = analogRead(_pin);
|
||||||
|
float scaled = _prescale * fullscale;
|
||||||
|
return scaled;
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
#ifndef __AP_ANALOG_SOURCE_ARDUINO_H__
|
#ifndef __AP_ANALOG_SOURCE_ARDUINO_H__
|
||||||
#define __AP_ANALOG_SOURCE_ARDUINO_H__
|
#define __AP_ANALOG_SOURCE_ARDUINO_H__
|
||||||
@ -7,11 +8,13 @@
|
|||||||
class AP_AnalogSource_Arduino : public AP_AnalogSource
|
class AP_AnalogSource_Arduino : public AP_AnalogSource
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
AP_AnalogSource_Arduino( int pin ) : _pin(pin) {}
|
AP_AnalogSource_Arduino( int pin, float prescale = 1.0 ) :
|
||||||
int read(void);
|
_pin(pin), _prescale(prescale) {}
|
||||||
|
float read(void);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int _pin;
|
int _pin;
|
||||||
|
float _prescale;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // __AP_ANALOG_SOURCE_ARDUINO_H__
|
#endif // __AP_ANALOG_SOURCE_ARDUINO_H__
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
class AP_AnalogSource
|
class AP_AnalogSource
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual int read(void) = 0;
|
virtual float read(void) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // __ANALOG_SOURCE_H__
|
#endif // __ANALOG_SOURCE_H__
|
||||||
|
Loading…
Reference in New Issue
Block a user