Files
upm/src/ds1808lc/ds1808lc.cxx
sisinty sasmita patra 1f18369fbe SWIG_JAVA: C++ Interfaces to Java interfaces, Modified one Java Example
This commit translates C++ interfaces to Java interfaces, previously C++ Interfaces implemented java classes.

    * Added java swig interface files for all C++ interfaces to simplify swig
    javaupm_iADC.i
    javaupm_iCO2Sensor.i
    javaupm_iHumiditySensor.i
    javaupm_iLightController.i
    javaupm_iLightSensor.i
    javaupm_iModuleStatus.i
    javaupm_interfaces.i
    javaupm_iPressureSensor.i
    javaupm_iTemperatureSensor.i

    <example Usage>
        %include"../interfaces/javaupm_iADC.i"

    * Modified swig interface files for few sensors that implements interfaces
    ads1x15
    bmp280
    bmpx8x
    ds1808lc
    hlg150h
    lp8860
    max44009
    ms5611
    si1132
    si7005
    t6713

    * Removed few methods that were mentioned Protected and made them public, so that menthods can be overridden

    * Made IModuleStatus virtual to avoid ambiguity in multiple inheritance
    For example
    class A {};
    class B : public A {};
    class C : public A {};
    class D : public B, public C {};

    This can be solved as
    class A {};
    class B : virtual public A {};
    class C : virtual public A {};
    class D : public B, public C {};

    * Modified java interface files to support multiple swig versions

    * Modified javaupm interface file to support standard auto load library code

    * Fixed autoloadlibrary tests for interfaces

    * Created one interface example separately <BME280_InterfaceExample.java>,
    <example Usage>
        BME280_InterfaceExample.java
    since we cann't define swig versions inside java example file.
    So, instaed added swig versions in Cmake.
    <example Usage>
         if (SWIG_VERSION VERSION_GREATER 3.0.8)
           add_example_with_path(BME280_InterfaceExample bmp280 bmp280)
         endif()

Signed-off-by: sisinty sasmita patra <sisinty.s.patra@intel.com>
2017-03-02 20:14:03 -08:00

134 lines
2.8 KiB
C++

#include <iostream>
#include <unistd.h>
#include <string.h>
#include <cmath>
#include "ds1808lc.hpp"
#include "mraa-utils.hpp"
#define DS1808_I2C_ADDR 0x28
#define DS1808_POT2_OFFSET 0x40
#define DS1808_MAX_POT_VALUE 0x20
#define DS1808_LOW_VALUE 32 // Lowest pot value that the eye can differentiate from 0
#define DS1808_HIGH_VALUE 51 // Highest pot value that the eye can differentiate from full
namespace upm {
DS1808LC::DS1808LC(int gpioPower, int i2cBus)
{
mraa_set_log_level(7);
pinPower = gpioPower;
i2c = new mraa::I2c(i2cBus);
status = i2c->address(DS1808_I2C_ADDR);
getBrightness();
}
DS1808LC::~DS1808LC()
{
}
bool DS1808LC::isPowered()
{
return static_cast<bool>(MraaUtils::getGpio(pinPower));
}
void DS1808LC::setPowerOn()
{
if (!isPowered())
{
MraaUtils::setGpio(pinPower, 1);
setBrightness(0);
}
}
void DS1808LC::setPowerOff()
{
MraaUtils::setGpio(pinPower, 0);
}
int DS1808LC::getBrightness()
{
uint8_t values[2];
if (i2c->read(values, 2) == 2) {
return getPercentBrightness(values[0], values[1]);
}
else
UPM_THROW("i2c read error");
}
void DS1808LC::setBrightness(int dutyPercent)
{
uint8_t values[2];
values[0] = getPot1Value(dutyPercent);
values[1] = getPot2Value(dutyPercent);
status = i2c->write(values, 2);
if (status != mraa::SUCCESS)
UPM_THROW("i2c write error");
}
//
// Helper Function
//
uint8_t DS1808LC::getPot1Value(int dutyPercent) {
uint8_t result = 0;
int scaledResistance = getScaledResistance(dutyPercent);
if (scaledResistance > DS1808_MAX_POT_VALUE)
result = DS1808_MAX_POT_VALUE;
else {
result = scaledResistance;
}
return result;
}
uint8_t DS1808LC::getPot2Value(int dutyPercent) {
uint8_t result = 0;
int scaledResistance = getScaledResistance(dutyPercent);
if (scaledResistance <= DS1808_MAX_POT_VALUE)
result = 0;
else {
result = scaledResistance - DS1808_MAX_POT_VALUE;
}
if (result > DS1808_MAX_POT_VALUE)
result = DS1808_MAX_POT_VALUE;
return result | DS1808_POT2_OFFSET;
}
int DS1808LC::getPercentBrightness(uint8_t val1, uint8_t val2) {
val2 = val2 & (~DS1808_POT2_OFFSET);
int scaledResistance = val1 + val2;
int percent;
if (scaledResistance < DS1808_LOW_VALUE)
percent = 100;
else if (scaledResistance > DS1808_HIGH_VALUE)
percent = 0;
else
percent = 100 - (((scaledResistance - DS1808_LOW_VALUE) * 100) / (DS1808_HIGH_VALUE - DS1808_LOW_VALUE));
return percent;
}
int DS1808LC::getScaledResistance(int dutyPercent) {
int scaledResistance;
if (dutyPercent == 0)
scaledResistance = 2 * DS1808_MAX_POT_VALUE;
else if (dutyPercent == 100)
scaledResistance = 0;
else
scaledResistance = (((100 - dutyPercent) * (DS1808_HIGH_VALUE - DS1808_LOW_VALUE)) / 100) + DS1808_LOW_VALUE;
return scaledResistance;
}
}