2015-04-13 16:56:21 -07:00
|
|
|
/*
|
2016-08-01 17:07:55 -07:00
|
|
|
* Authors: Brendan Le Foll <brendan.le.foll@intel.com>
|
|
|
|
|
* Mihai Tudor Panu <mihai.tudor.panu@intel.com>
|
|
|
|
|
* Sarah Knepper <sarah.knepper@intel.com>
|
|
|
|
|
* Copyright (c) 2014 - 2016 Intel Corporation.
|
2015-04-13 16:56:21 -07:00
|
|
|
*
|
|
|
|
|
* 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.
|
|
|
|
|
*/
|
2016-08-01 17:07:55 -07:00
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
#include <mraa/aio.hpp>
|
|
|
|
|
|
|
|
|
|
namespace upm {
|
|
|
|
|
|
2015-04-13 16:56:21 -07:00
|
|
|
/**
|
2016-09-09 14:10:30 -07:00
|
|
|
* @library light
|
|
|
|
|
* @sensor light
|
|
|
|
|
* @comname Light Sensor
|
2015-04-13 16:56:21 -07:00
|
|
|
* @type light
|
|
|
|
|
* @man seeed
|
|
|
|
|
* @con analog
|
|
|
|
|
* @kit gsk
|
|
|
|
|
*
|
2016-09-09 14:10:30 -07:00
|
|
|
* @brief API for the Light Sensor
|
2015-04-13 16:56:21 -07:00
|
|
|
*
|
2016-09-09 14:10:30 -07:00
|
|
|
* The light sensor detects the intensity of the ambient light.
|
2015-04-13 16:56:21 -07:00
|
|
|
* As the light intensity of the environment increases, the resistance
|
2015-08-09 22:51:25 +03:00
|
|
|
* of the sensor decreases. This means the raw value from the
|
|
|
|
|
* analog pin is larger in bright light and smaller in the dark.
|
2015-04-13 16:56:21 -07:00
|
|
|
* An approximate lux value can also be returned.
|
|
|
|
|
*
|
2016-09-09 14:10:30 -07:00
|
|
|
* @image html light.jpg
|
|
|
|
|
* @snippet light.cxx Interesting
|
2015-04-13 16:56:21 -07:00
|
|
|
*/
|
2016-09-09 14:10:30 -07:00
|
|
|
class Light {
|
2016-08-01 17:07:55 -07:00
|
|
|
public:
|
|
|
|
|
/**
|
2016-09-09 14:10:30 -07:00
|
|
|
* analog light sensor constructor
|
2016-08-01 17:07:55 -07:00
|
|
|
*
|
|
|
|
|
* @param pin Analog pin to use
|
|
|
|
|
*/
|
2016-09-09 14:10:30 -07:00
|
|
|
Light(unsigned int pin);
|
2016-08-01 17:07:55 -07:00
|
|
|
/**
|
2016-09-09 14:10:30 -07:00
|
|
|
* Light destructor
|
2016-08-01 17:07:55 -07:00
|
|
|
*/
|
2016-09-09 14:10:30 -07:00
|
|
|
~Light();
|
2016-08-01 17:07:55 -07:00
|
|
|
/**
|
|
|
|
|
* Gets the raw value from the AIO pin
|
|
|
|
|
*
|
|
|
|
|
* @return Raw value from the ADC
|
|
|
|
|
*/
|
|
|
|
|
float raw_value();
|
|
|
|
|
/**
|
|
|
|
|
* Gets an approximate light value, in lux, from the sensor
|
|
|
|
|
*
|
|
|
|
|
* @return Normalized light reading in lux
|
|
|
|
|
*/
|
|
|
|
|
int value();
|
2016-09-09 14:10:30 -07:00
|
|
|
|
|
|
|
|
/* Sensor name
|
|
|
|
|
*
|
|
|
|
|
* @return Sensor name
|
|
|
|
|
*/
|
|
|
|
|
std::string name()
|
|
|
|
|
{
|
|
|
|
|
return m_name;
|
|
|
|
|
}
|
|
|
|
|
|
2016-08-01 17:07:55 -07:00
|
|
|
private:
|
|
|
|
|
mraa_aio_context m_aio;
|
2016-09-09 14:10:30 -07:00
|
|
|
const std::string m_name = "Light Sensor";
|
2016-08-01 17:07:55 -07:00
|
|
|
};
|
|
|
|
|
}
|