Update xdrv_20_hue.ino

This commit is contained in:
gemu2015 2019-09-30 10:31:13 +02:00
parent 6eb3c74689
commit 768c264d04
1 changed files with 38 additions and 16 deletions

View File

@ -276,6 +276,12 @@ void HueLightStatus1(uint8_t device, String *response)
if (bri > 254) bri = 254; // Philips Hue bri is between 1 and 254 if (bri > 254) bri = 254; // Philips Hue bri is between 1 and 254
if (bri < 1) bri = 1; if (bri < 1) bri = 1;
#ifdef USE_SHUTTER
if (ShutterState(device)) {
bri = (float)(Settings.shutter_invert[device-1] ? 100 - Settings.shutter_position[device-1] : Settings.shutter_position[device-1]) / 100;
}
#endif
if (light_type) { if (light_type) {
light_state.getHSB(&hue, &sat, nullptr); light_state.getHSB(&hue, &sat, nullptr);
@ -452,7 +458,6 @@ void HueGlobalConfig(String *path)
response += ",\""; response += ",\"";
} }
} }
response += F("},\"groups\":{},\"schedules\":{},\"config\":"); response += F("},\"groups\":{},\"schedules\":{},\"config\":");
HueConfigResponse(&response); HueConfigResponse(&response);
response += "}"; response += "}";
@ -502,7 +507,6 @@ void HueLights(String *path)
Script_Check_Hue(&response); Script_Check_Hue(&response);
#endif #endif
response += "}"; response += "}";
} }
else if (path->endsWith("/state")) { // Got ID/state else if (path->endsWith("/state")) { // Got ID/state
path->remove(0,8); // Remove /lights/ path->remove(0,8); // Remove /lights/
@ -531,19 +535,32 @@ void HueLights(String *path)
response.replace("{id", String(EncodeLightId(device))); response.replace("{id", String(EncodeLightId(device)));
response.replace("{cm", "on"); response.replace("{cm", "on");
on = hue_json["on"]; #ifdef USE_SHUTTER
switch(on) if (ShutterState(device)) {
{ if (!change) {
case false : ExecuteCommandPower(device, POWER_OFF, SRC_HUE); on = hue_json["on"];
response.replace("{re", "false"); bri = on ? 1.0f : 0.0f; // when bri is not part of this request then calculate it
break; change = true;
case true : ExecuteCommandPower(device, POWER_ON, SRC_HUE); }
response.replace("{re", "true"); response.replace("{re", on ? "true" : "false");
break; } else {
default : response.replace("{re", (power & (1 << (device-1))) ? "true" : "false"); #endif
break; on = hue_json["on"];
switch(on)
{
case false : ExecuteCommandPower(device, POWER_OFF, SRC_HUE);
response.replace("{re", "false");
break;
case true : ExecuteCommandPower(device, POWER_ON, SRC_HUE);
response.replace("{re", "true");
break;
default : response.replace("{re", (power & (1 << (device-1))) ? "true" : "false");
break;
}
resp = true;
#ifdef USE_SHUTTER
} }
resp = true; #endif // USE_SHUTTER
} }
if (light_type && (local_light_subtype >= LST_SINGLE)) { if (light_type && (local_light_subtype >= LST_SINGLE)) {
@ -649,6 +666,12 @@ void HueLights(String *path)
resp = true; resp = true;
} }
if (change) { if (change) {
#ifdef USE_SHUTTER
if (ShutterState(device)) {
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("Settings.shutter_invert: %d"), Settings.shutter_invert[device-1]);
SetShutterPosition(device, bri * 100.0f );
} else
#endif
if (light_type && (local_light_subtype > LST_NONE)) { // not relay if (light_type && (local_light_subtype > LST_NONE)) { // not relay
if (!Settings.flag3.pwm_multi_channels) { if (!Settings.flag3.pwm_multi_channels) {
if (g_gotct) { if (g_gotct) {
@ -687,7 +710,7 @@ void HueLights(String *path)
if (device>devices_present) { if (device>devices_present) {
Script_HueStatus(&response,device-devices_present-1); Script_HueStatus(&response,device-devices_present-1);
goto exit; goto exit;
} }
#endif #endif
if ((device < 1) || (device > maxhue)) { if ((device < 1) || (device > maxhue)) {
@ -696,7 +719,6 @@ void HueLights(String *path)
response += F("{\"state\":"); response += F("{\"state\":");
HueLightStatus1(device, &response); HueLightStatus1(device, &response);
HueLightStatus2(device, &response); HueLightStatus2(device, &response);
} }
else { else {
response = "{}"; response = "{}";