mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
[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:
parent
0c2d697909
commit
24c1691c8b
@ -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
|
||||||
|
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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\":"
|
||||||
|
+ hsb.getHue().intValue() + ",\"saturation\":" + hsb.getSaturation().intValue() + "}");
|
||||||
}
|
}
|
||||||
sendMQTT("{\"state\":\"ON\",\"level\":" + hsb.getBrightness().intValue() + ",\"hue\":"
|
|
||||||
+ 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()) + "}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user