/**
\file ExtendedColorHueStrategy.cpp
Copyright Notice\n
Copyright (C) 2017 Jan Rogall - developer\n
Copyright (C) 2017 Moritz Wirger - developer\n
This file is part of hueplusplus.
hueplusplus is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
hueplusplus is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with hueplusplus. If not, see .
**/
#include "hueplusplus/ExtendedColorHueStrategy.h"
#include
#include
#include
#include "hueplusplus/HueConfig.h"
bool hueplusplus::ExtendedColorHueStrategy::alertHueSaturation(uint16_t hue, uint8_t sat, HueLight& light) const
{
light.refreshState();
std::string cType = light.state["state"]["colormode"].get();
bool on = light.state["state"]["on"].get();
if (cType == "hs")
{
uint16_t oldHue = light.state["state"]["hue"].get();
uint8_t oldSat = light.state["state"]["sat"].get();
if (!light.setColorHueSaturation(hue, sat, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorHueSaturation(oldHue, oldSat, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorHueSaturation(oldHue, oldSat, 1);
}
}
else if (cType == "xy")
{
float oldX = light.state["state"]["xy"][0].get();
float oldY = light.state["state"]["xy"][1].get();
if (!light.setColorHueSaturation(hue, sat, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorXY(oldX, oldY, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorXY(oldX, oldY, 1);
}
}
else if (cType == "ct")
{
uint16_t oldCT = light.state["state"]["ct"].get();
if (!light.setColorHueSaturation(hue, sat, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorTemperature(oldCT, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorTemperature(oldCT, 1);
}
}
else
{
return false;
}
}
bool hueplusplus::ExtendedColorHueStrategy::alertXY(float x, float y, HueLight& light) const
{
light.refreshState();
std::string cType = light.state["state"]["colormode"].get();
bool on = light.state["state"]["on"].get();
if (cType == "hs")
{
uint16_t oldHue = light.state["state"]["hue"].get();
uint8_t oldSat = light.state["state"]["sat"].get();
if (!light.setColorXY(x, y, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorHueSaturation(oldHue, oldSat, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorHueSaturation(oldHue, oldSat, 1);
}
}
else if (cType == "xy")
{
float oldX = light.state["state"]["xy"][0].get();
float oldY = light.state["state"]["xy"][1].get();
if (!light.setColorXY(x, y, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorXY(oldX, oldY, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorXY(oldX, oldY, 1);
}
}
else if (cType == "ct")
{
uint16_t oldCT = light.state["state"]["ct"].get();
if (!light.setColorXY(x, y, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorTemperature(oldCT, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorTemperature(oldCT, 1);
}
}
else
{
return false;
}
}
bool hueplusplus::ExtendedColorHueStrategy::alertRGB(uint8_t r, uint8_t g, uint8_t b, HueLight& light) const
{
light.refreshState();
std::string cType = light.state["state"]["colormode"].get();
bool on = light.state["state"]["on"].get();
if (cType == "hs")
{
uint16_t oldHue = light.state["state"]["hue"].get();
uint8_t oldSat = light.state["state"]["sat"].get();
if (!light.setColorRGB(r, g, b, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorHueSaturation(oldHue, oldSat, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorHueSaturation(oldHue, oldSat, 1);
}
}
else if (cType == "xy")
{
float oldX = light.state["state"]["xy"][0].get();
float oldY = light.state["state"]["xy"][1].get();
if (!light.setColorRGB(r, g, b, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorXY(oldX, oldY, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorXY(oldX, oldY, 1);
}
}
else if (cType == "ct")
{
uint16_t oldCT = light.state["state"]["ct"].get();
if (!light.setColorRGB(r, g, b, 1))
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_PRE_ALERT_DELAY));
if (!light.alert())
{
return false;
}
std::this_thread::sleep_for(std::chrono::milliseconds(c_POST_ALERT_DELAY));
if (!on)
{
light.setColorTemperature(oldCT, 1);
return light.OffNoRefresh(1);
}
else
{
return light.setColorTemperature(oldCT, 1);
}
}
else
{
return false;
}
}