/** \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; } }