[espmilight] Add color channels ability to trigger white LEDs (#11047)

* Add white shortcut for sat threshold


Signed-off-by: Matthew Skinner <matt@pcmus.com>

* Fix compiler warnings.

Signed-off-by: Matthew Skinner <matt@pcmus.com>
This commit is contained in:
Matthew Skinner 2021-07-25 20:43:28 +10:00 committed by GitHub
parent 0c2d697909
commit 24c1691c8b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 27 additions and 17 deletions

View File

@ -105,7 +105,7 @@ Note that the group 0 (or ALL group) is not autodiscovered as a thing and thus h
| `dimmedCT` | Traditional globes grow warmer the more they are dimmed. Set this to 370, or leave blank to disable. | N | blank | | `dimmedCT` | Traditional globes grow warmer the more they are dimmed. Set this to 370, or leave blank to disable. | N | blank |
| `oneTriggersNightMode` | Night mode is a much lower level of light and this feature allows it to be auto selected when your fader/slider moves to 1%. NOTE: Night mode by design locks out some controls of a physical remote, so this feature is disabled by default. | Y | false | | `oneTriggersNightMode` | Night mode is a much lower level of light and this feature allows it to be auto selected when your fader/slider moves to 1%. NOTE: Night mode by design locks out some controls of a physical remote, so this feature is disabled by default. | Y | false |
| `powerFailsToMinimum` | If lights loose power from the power switch OR a power outage, they will default to using the lowest brightness if the light was turned off before the power failure occurred. | Y | true | | `powerFailsToMinimum` | If lights loose power from the power switch OR a power outage, they will default to using the lowest brightness if the light was turned off before the power failure occurred. | Y | true |
| `whiteThreshold` | RGBW globes do not respond to saturation changes, so this feature allows you to specify a number that if the saturation drops below, it will trigger the white mode. -1 will disable this feature. | Y | 12 | | `whiteThreshold` | This feature allows you to use a color control to change to using the real white LEDs when the saturation is equal to, or below this threshold. -1 will disable this feature. | Y | 12 |
## Channels ## Channels

View File

@ -70,7 +70,7 @@ public class EspMilightHubDiscoveryService extends AbstractMQTTDiscovery {
String globeType = (cutTopic.substring(0, index)); String globeType = (cutTopic.substring(0, index));
String remoteGroupID = (cutTopic.substring(index + 1, index + 2)); String remoteGroupID = (cutTopic.substring(index + 1, index + 2));
// openHAB's framework has better code for handling groups then the firmware does // openHAB's framework has better code for handling groups then the firmware does
if (!remoteGroupID.equals("0")) {// Users can manually add group 0 things if they wish if (!"0".equals(remoteGroupID)) {// Users can manually add group 0 things if they wish
publishDevice(connectionBridge, connection, topic, remoteCode, globeType, remoteGroupID); publishDevice(connectionBridge, connection, topic, remoteCode, globeType, remoteGroupID);
} }
} }

View File

@ -78,7 +78,7 @@ public class EspMilightHubHandler extends BaseThingHandler implements MqttConnec
void changeChannel(String channel, State state) { void changeChannel(String channel, State state) {
updateState(new ChannelUID(channelPrefix + channel), state); updateState(new ChannelUID(channelPrefix + channel), state);
// Remote code of 0 means that all channels need to follow this change. // Remote code of 0 means that all channels need to follow this change.
if (remotesGroupID.equals("0")) { if ("0".equals(remotesGroupID)) {
switch (globeType) { switch (globeType) {
// These two are 8 channel remotes // These two are 8 channel remotes
case "fut091": case "fut091":
@ -110,20 +110,20 @@ public class EspMilightHubHandler extends BaseThingHandler implements MqttConnec
String bulbState = Helper.resolveJSON(messageJSON, "\"state\":\"", 3); String bulbState = Helper.resolveJSON(messageJSON, "\"state\":\"", 3);
String bulbLevel = Helper.resolveJSON(messageJSON, "\"level\":", 3); String bulbLevel = Helper.resolveJSON(messageJSON, "\"level\":", 3);
if (!bulbLevel.isEmpty()) { if (!bulbLevel.isEmpty()) {
if (bulbLevel.equals("0") || bulbState.equals("OFF")) { if ("0".equals(bulbLevel) || "OFF".equals(bulbState)) {
changeChannel(CHANNEL_LEVEL, OnOffType.OFF); changeChannel(CHANNEL_LEVEL, OnOffType.OFF);
tempBulbLevel = BigDecimal.ZERO; tempBulbLevel = BigDecimal.ZERO;
} else { } else {
tempBulbLevel = new BigDecimal(bulbLevel); tempBulbLevel = new BigDecimal(bulbLevel);
changeChannel(CHANNEL_LEVEL, new PercentType(tempBulbLevel)); changeChannel(CHANNEL_LEVEL, new PercentType(tempBulbLevel));
} }
} else if (bulbState.equals("ON") || bulbState.equals("OFF")) { // NOTE: Level is missing when this runs } else if ("ON".equals(bulbState) || "OFF".equals(bulbState)) { // NOTE: Level is missing when this runs
changeChannel(CHANNEL_LEVEL, OnOffType.valueOf(bulbState)); changeChannel(CHANNEL_LEVEL, OnOffType.valueOf(bulbState));
} }
bulbMode = Helper.resolveJSON(messageJSON, "\"bulb_mode\":\"", 5); bulbMode = Helper.resolveJSON(messageJSON, "\"bulb_mode\":\"", 5);
switch (bulbMode) { switch (bulbMode) {
case "white": case "white":
if (!globeType.equals("cct") && !globeType.equals("fut091")) { if (!"cct".equals(globeType) && !"fut091".equals(globeType)) {
changeChannel(CHANNEL_BULB_MODE, new StringType("white")); changeChannel(CHANNEL_BULB_MODE, new StringType("white"));
changeChannel(CHANNEL_COLOUR, new HSBType("0,0," + tempBulbLevel)); changeChannel(CHANNEL_COLOUR, new HSBType("0,0," + tempBulbLevel));
changeChannel(CHANNEL_DISCO_MODE, new StringType("None")); changeChannel(CHANNEL_DISCO_MODE, new StringType("None"));
@ -149,7 +149,7 @@ public class EspMilightHubHandler extends BaseThingHandler implements MqttConnec
} }
break; break;
case "scene": case "scene":
if (!globeType.equals("cct") && !globeType.equals("fut091")) { if (!"cct".equals(globeType) && !"fut091".equals(globeType)) {
changeChannel(CHANNEL_BULB_MODE, new StringType("scene")); changeChannel(CHANNEL_BULB_MODE, new StringType("scene"));
} }
String bulbDiscoMode = Helper.resolveJSON(messageJSON, "\"mode\":", 1); String bulbDiscoMode = Helper.resolveJSON(messageJSON, "\"mode\":", 1);
@ -158,7 +158,7 @@ public class EspMilightHubHandler extends BaseThingHandler implements MqttConnec
} }
break; break;
case "night": case "night":
if (!globeType.equals("cct") && !globeType.equals("fut091")) { if (!"cct".equals(globeType) && !"fut091".equals(globeType)) {
changeChannel(CHANNEL_BULB_MODE, new StringType("night")); changeChannel(CHANNEL_BULB_MODE, new StringType("night"));
if (config.oneTriggersNightMode) { if (config.oneTriggersNightMode) {
changeChannel(CHANNEL_LEVEL, new PercentType("1")); changeChannel(CHANNEL_LEVEL, new PercentType("1"));
@ -219,13 +219,13 @@ public class EspMilightHubHandler extends BaseThingHandler implements MqttConnec
} else if (PercentType.ZERO.equals(hsb.getBrightness())) { } else if (PercentType.ZERO.equals(hsb.getBrightness())) {
turnOff(); turnOff();
return; return;
} else if (config.whiteThreshold != -1 && hsb.getSaturation().intValue() <= config.whiteThreshold } else if (config.whiteThreshold != -1 && hsb.getSaturation().intValue() <= config.whiteThreshold) {
&& "rgbw".equals(globeType)) { sendMQTT("{\"command\":\"set_white\"}");// Can't send the command and level in the same message.
sendMQTT("{\"command\":\"set_white\"}"); sendMQTT("{\"level\":" + hsb.getBrightness().intValue() + "}");
return; } else {
}
sendMQTT("{\"state\":\"ON\",\"level\":" + hsb.getBrightness().intValue() + ",\"hue\":" sendMQTT("{\"state\":\"ON\",\"level\":" + hsb.getBrightness().intValue() + ",\"hue\":"
+ hsb.getHue().intValue() + ",\"saturation\":" + hsb.getSaturation().intValue() + "}"); + hsb.getHue().intValue() + ",\"saturation\":" + hsb.getSaturation().intValue() + "}");
}
savedLevel = hsb.getBrightness().toBigDecimal(); savedLevel = hsb.getBrightness().toBigDecimal();
return; return;
} else if (command instanceof PercentType) { } else if (command instanceof PercentType) {
@ -239,8 +239,8 @@ public class EspMilightHubHandler extends BaseThingHandler implements MqttConnec
} }
sendMQTT("{\"state\":\"ON\",\"level\":" + command + "}"); sendMQTT("{\"state\":\"ON\",\"level\":" + command + "}");
savedLevel = percentType.toBigDecimal(); savedLevel = percentType.toBigDecimal();
if (globeType.equals("rgb_cct") || globeType.equals("fut089")) { if ("rgb_cct".equals(globeType) || "fut089".equals(globeType)) {
if (config.dimmedCT > 0 && bulbMode.equals("white")) { if (config.dimmedCT > 0 && "white".equals(bulbMode)) {
sendMQTT("{\"state\":\"ON\",\"color_temp\":" + autoColourTemp(savedLevel.intValue()) + "}"); sendMQTT("{\"state\":\"ON\",\"color_temp\":" + autoColourTemp(savedLevel.intValue()) + "}");
} }
} }

View File

@ -47,6 +47,15 @@
<default>32</default> <default>32</default>
</parameter> </parameter>
<parameter name="whiteThreshold" type="integer" required="true" min="-1" max="99">
<label>White Threshold</label>
<description>Saturation values at or below this value on a RGBW color control will trigger the white mode. -1 will
disable
this feature.
</description>
<default>6</default>
</parameter>
<parameter name="favouriteWhite" type="integer" required="true" min="153" max="370"> <parameter name="favouriteWhite" type="integer" required="true" min="153" max="370">
<label>Favourite White</label> <label>Favourite White</label>
<description>When a shortcut triggers white mode, use this for the colour white.</description> <description>When a shortcut triggers white mode, use this for the colour white.</description>
@ -101,7 +110,8 @@
<parameter name="whiteThreshold" type="integer" required="true" min="-1" max="99"> <parameter name="whiteThreshold" type="integer" required="true" min="-1" max="99">
<label>White Threshold</label> <label>White Threshold</label>
<description>RGBW saturation changes, will trigger the white mode. -1 will disable this feature. <description>Saturation values at or below this value on a RGBW color control will trigger the white mode. -1 will
disable this feature.
</description> </description>
<default>12</default> <default>12</default>
</parameter> </parameter>