2022-02-05 20:09:48 +01:00
|
|
|
#include <LightController.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <Arduino.h>
|
|
|
|
#include <EEPROM.h>
|
|
|
|
|
2022-02-05 22:23:17 +01:00
|
|
|
LightController::LightController(const int bjtPins[], __SIZE_TYPE__ bjtCount)
|
2022-02-05 20:09:48 +01:00
|
|
|
{
|
|
|
|
this->bjtCount = bjtCount;
|
|
|
|
this->bjtPins = bjtPins;
|
|
|
|
this->bjtState = new int[bjtCount];
|
2022-02-05 22:23:17 +01:00
|
|
|
initializePins();
|
|
|
|
initializeState();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LightController::initializeState()
|
|
|
|
{
|
|
|
|
initializeStateDefaultValues();
|
|
|
|
restoreState();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LightController::initializePins()
|
|
|
|
{
|
|
|
|
for (__SIZE_TYPE__ i = 0; i < bjtCount; i++)
|
|
|
|
{
|
|
|
|
pinMode(bjtPins[i], OUTPUT);
|
|
|
|
}
|
|
|
|
}
|
2022-02-05 20:50:33 +01:00
|
|
|
|
2022-02-05 22:23:17 +01:00
|
|
|
void LightController::initializeStateDefaultValues()
|
|
|
|
{
|
|
|
|
for (__SIZE_TYPE__ i = 0; i < bjtCount && i < sizeof(bjtState) / sizeof(bjtState[0]); i++)
|
2022-02-05 20:50:33 +01:00
|
|
|
{
|
|
|
|
bjtState[i] = 0;
|
|
|
|
}
|
2022-02-05 22:23:17 +01:00
|
|
|
}
|
2022-02-05 20:50:33 +01:00
|
|
|
|
2022-02-05 22:23:17 +01:00
|
|
|
void LightController::restoreState()
|
|
|
|
{
|
|
|
|
for (__SIZE_TYPE__ i = 0; i < bjtCount && i < sizeof(bjtState) / sizeof(bjtState[0]); i++)
|
2022-02-05 20:50:33 +01:00
|
|
|
{
|
|
|
|
bjtState[i] = EEPROM.read(i);
|
|
|
|
commitPinState(i);
|
|
|
|
}
|
2022-02-05 20:09:48 +01:00
|
|
|
}
|
|
|
|
|
2022-02-05 20:50:33 +01:00
|
|
|
void LightController::updateState(const char data[], int steps)
|
2022-02-05 20:09:48 +01:00
|
|
|
{
|
2022-02-05 22:23:17 +01:00
|
|
|
for (__SIZE_TYPE__ i = 0; i < bjtCount; i++)
|
2022-02-05 20:09:48 +01:00
|
|
|
{
|
|
|
|
parseRelativeState(data, i, steps);
|
|
|
|
setAbsoluteState(data, i);
|
|
|
|
commitState(i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void LightController::parseRelativeState(const char data[], int index, int steps)
|
|
|
|
{
|
|
|
|
char numChar[2];
|
|
|
|
itoa(index, numChar, 10);
|
|
|
|
|
|
|
|
if (data[0] == numChar[0])
|
|
|
|
{
|
|
|
|
if (data[1] == 't')
|
|
|
|
{
|
|
|
|
if (bjtState[index] != 0)
|
|
|
|
{
|
|
|
|
bjtState[index] = 0;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
bjtState[index] = 255;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (data[1] == 'i')
|
|
|
|
{
|
2022-02-05 20:50:33 +01:00
|
|
|
bjtState[index] = clampState(bjtState[index] + steps);
|
2022-02-05 20:09:48 +01:00
|
|
|
}
|
|
|
|
else if (data[1] == 'd')
|
|
|
|
{
|
2022-02-05 20:50:33 +01:00
|
|
|
bjtState[index] = clampState(bjtState[index] - steps);
|
2022-02-05 20:09:48 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void LightController::setAbsoluteState(const char data[], int index)
|
|
|
|
{
|
|
|
|
if (!strcmp(data, "off"))
|
|
|
|
{
|
|
|
|
bjtState[index] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!strcmp(data, "on"))
|
|
|
|
{
|
|
|
|
bjtState[index] = 255;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int LightController::clampState(int stateValue)
|
|
|
|
{
|
2022-02-05 20:50:33 +01:00
|
|
|
int clampedState = stateValue;
|
2022-02-05 20:09:48 +01:00
|
|
|
if (stateValue > 255)
|
|
|
|
{
|
|
|
|
clampedState = 255;
|
|
|
|
}
|
|
|
|
else if (stateValue < 0)
|
|
|
|
{
|
|
|
|
clampedState = 0;
|
|
|
|
}
|
|
|
|
return clampedState;
|
|
|
|
}
|
|
|
|
|
|
|
|
void LightController::commitState(int index)
|
|
|
|
{
|
2022-02-05 20:50:33 +01:00
|
|
|
commitPinState(index);
|
2022-02-05 20:09:48 +01:00
|
|
|
EEPROM.update(index, bjtState[index]);
|
|
|
|
}
|
|
|
|
|
2022-02-05 20:50:33 +01:00
|
|
|
void LightController::commitPinState(int index)
|
|
|
|
{
|
|
|
|
analogWrite(bjtPins[index], bjtState[index]);
|
|
|
|
}
|
|
|
|
|
2022-02-05 20:09:48 +01:00
|
|
|
int LightController::getBjtCount()
|
|
|
|
{
|
|
|
|
return bjtCount;
|
|
|
|
}
|
2022-02-05 20:50:33 +01:00
|
|
|
const int *LightController::getBjtPins()
|
2022-02-05 20:09:48 +01:00
|
|
|
{
|
|
|
|
return bjtPins;
|
|
|
|
}
|
|
|
|
int *LightController::getBjtState()
|
|
|
|
{
|
|
|
|
return bjtState;
|
|
|
|
}
|