Added interface iRotaryAngle

Signed-off-by: Stefan Andritoiu <stefan.andritoiu@gmail.com>
This commit is contained in:
Stefan Andritoiu 2018-06-20 18:27:59 +03:00 committed by Serban Waltter
parent ab54cb7058
commit 3dc21b1dc8
8 changed files with 92 additions and 6 deletions

View File

@ -34,6 +34,11 @@ namespace upm
public: public:
virtual ~iProximity() {} virtual ~iProximity() {}
/**
* Get proximity value from sensor data.
*
* @return Proximity value as volts.
*/
virtual float getValue() = 0; virtual float getValue() = 0;
}; };
} }

View File

@ -0,0 +1,44 @@
/*
* Author: Mihai Stefanescu <mihai.stefanescu@rinftech.com>
* Copyright (c) 2018 Intel Corporation.
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
#pragma once
namespace upm
{
/**
* @brief Interface for Rotary Angle sensors
*/
class iRotaryAngle
{
public:
virtual ~iRotaryAngle() {}
/**
* Get rotation value from sensor data.
*
* @return rotation value.
*/
virtual float getValue() = 0;
};
}

View File

@ -77,3 +77,8 @@ float GroveRotary::rel_rad()
{ {
return GroveRotary::rel_deg() * M_PI / 180.0; return GroveRotary::rel_deg() * M_PI / 180.0;
} }
float GroveRotary::getValue()
{
return GroveRotary::abs_value();
}

View File

@ -29,6 +29,7 @@
#include <string> #include <string>
#include <mraa/aio.hpp> #include <mraa/aio.hpp>
#include "grovebase.hpp" #include "grovebase.hpp"
#include <interfaces/iRotaryAngle.hpp>
namespace upm { namespace upm {
@ -53,7 +54,7 @@ namespace upm {
* @image html rotaryencoder.jpg * @image html rotaryencoder.jpg
* @snippet grove-groverotary.cxx Interesting * @snippet grove-groverotary.cxx Interesting
*/ */
class GroveRotary: public Grove { class GroveRotary: public Grove, virtual public iRotaryAngle {
public: public:
/** /**
* Grove rotary angle sensor constructor * Grove rotary angle sensor constructor
@ -101,6 +102,14 @@ class GroveRotary: public Grove {
* @return Signed radians from the ADC * @return Signed radians from the ADC
*/ */
float rel_rad(); float rel_rad();
/**
* Get rotation value as raw degrees from the AIO pin.
*
* @return rotation value.
*/
virtual float getValue();
private: private:
mraa_aio_context m_aio; mraa_aio_context m_aio;
static const int m_max_angle = 300; static const int m_max_angle = 300;

View File

@ -76,3 +76,8 @@ float Rotary::rel_rad()
{ {
return Rotary::rel_deg() * M_PI / 180.0; return Rotary::rel_deg() * M_PI / 180.0;
} }
float Rotary::getValue()
{
return Rotary::abs_value();
}

View File

@ -30,6 +30,7 @@
#include <mraa/aio.hpp> #include <mraa/aio.hpp>
#include "rotary.hpp" #include "rotary.hpp"
#include <interfaces/iRotaryAngle.hpp>
namespace upm { namespace upm {
@ -59,7 +60,7 @@ namespace upm {
* @image html rotary.jpg * @image html rotary.jpg
* @snippet rotary.cxx Interesting * @snippet rotary.cxx Interesting
*/ */
class Rotary{ class Rotary : virtual public iRotaryAngle {
public: public:
/** /**
* Rotary angle sensor constructor * Rotary angle sensor constructor
@ -77,6 +78,7 @@ class Rotary{
* @return Unsigned value from the ADC * @return Unsigned value from the ADC
*/ */
float abs_value(); float abs_value();
/** /**
* Gets absolute raw degrees from the AIO pin * Gets absolute raw degrees from the AIO pin
* *
@ -107,6 +109,14 @@ class Rotary{
* @return Signed radians from the ADC * @return Signed radians from the ADC
*/ */
float rel_rad(); float rel_rad();
/**
* Get rotation value as raw degrees from the AIO pin.
*
* @return rotation value.
*/
virtual float getValue();
std::string name(){ return "Rotary Angle Sensor";} std::string name(){ return "Rotary Angle Sensor";}
private: private:
mraa_aio_context m_aio; mraa_aio_context m_aio;

View File

@ -53,4 +53,6 @@ int RotaryEncoder::position()
return rotaryencoder_get_position(m_rotaryencoder); return rotaryencoder_get_position(m_rotaryencoder);
} }
float RotaryEncoder::getValue() {
return (float) RotaryEncoder::position();
}

View File

@ -24,6 +24,7 @@
#pragma once #pragma once
#include "rotaryencoder.h" #include "rotaryencoder.h"
#include <interfaces/iRotaryAngle.hpp>
namespace upm { namespace upm {
@ -60,7 +61,7 @@ namespace upm {
* @snippet rotaryencoder.cxx Interesting * @snippet rotaryencoder.cxx Interesting
*/ */
class RotaryEncoder { class RotaryEncoder : virtual public iRotaryAngle {
public: public:
/** /**
* RotaryEncoder constructor * RotaryEncoder constructor
@ -87,6 +88,13 @@ namespace upm {
*/ */
int position(); int position();
/**
* Get rotation value from sensor data.
*
* @return rotation value.
*/
virtual float getValue();
private: private:
/* Disable implicit copy and assignment operators */ /* Disable implicit copy and assignment operators */
RotaryEncoder(const RotaryEncoder&) = delete; RotaryEncoder(const RotaryEncoder&) = delete;
@ -95,5 +103,3 @@ namespace upm {
rotaryencoder_context m_rotaryencoder; rotaryencoder_context m_rotaryencoder;
}; };
} }