From 354bd6022f56530b7553ce0521168a5048a7da1c Mon Sep 17 00:00:00 2001 From: Andrew Fiddian-Green Date: Sat, 21 Dec 2024 10:49:51 +0000 Subject: [PATCH] [tapocontrol] support QuantityType commands Signed-off-by: Andrew Fiddian-Green --- .../devices/wifi/bulb/TapoBulbHandler.java | 11 ++++++-- .../lightstrip/TapoLightStripHandler.java | 27 ++++++++++++------- 2 files changed, 26 insertions(+), 12 deletions(-) diff --git a/bundles/org.openhab.binding.tapocontrol/src/main/java/org/openhab/binding/tapocontrol/internal/devices/wifi/bulb/TapoBulbHandler.java b/bundles/org.openhab.binding.tapocontrol/src/main/java/org/openhab/binding/tapocontrol/internal/devices/wifi/bulb/TapoBulbHandler.java index e09427319a288..2cc7ea0a9f54b 100644 --- a/bundles/org.openhab.binding.tapocontrol/src/main/java/org/openhab/binding/tapocontrol/internal/devices/wifi/bulb/TapoBulbHandler.java +++ b/bundles/org.openhab.binding.tapocontrol/src/main/java/org/openhab/binding/tapocontrol/internal/devices/wifi/bulb/TapoBulbHandler.java @@ -25,6 +25,7 @@ import org.openhab.core.library.types.HSBType; import org.openhab.core.library.types.OnOffType; import org.openhab.core.library.types.PercentType; +import org.openhab.core.library.types.QuantityType; import org.openhab.core.library.unit.Units; import org.openhab.core.thing.ChannelGroupUID; import org.openhab.core.thing.ChannelUID; @@ -147,8 +148,14 @@ private void handleColorCommand(Command command) { } private void handleColorTempCommand(Command command) { - if (command instanceof DecimalType decimalCommand) { - setColorTemp(decimalCommand.intValue()); + QuantityType kelvinQuantity = null; + if (command instanceof QuantityType genericQuantity) { + kelvinQuantity = genericQuantity.toInvertibleUnit(Units.KELVIN); + } else if (command instanceof DecimalType decimal) { + kelvinQuantity = QuantityType.valueOf(decimal.intValue(), Units.KELVIN); + } + if (kelvinQuantity != null) { + setColorTemp(kelvinQuantity.intValue()); } } diff --git a/bundles/org.openhab.binding.tapocontrol/src/main/java/org/openhab/binding/tapocontrol/internal/devices/wifi/lightstrip/TapoLightStripHandler.java b/bundles/org.openhab.binding.tapocontrol/src/main/java/org/openhab/binding/tapocontrol/internal/devices/wifi/lightstrip/TapoLightStripHandler.java index 4e9c721c2c5fa..87c9835d72600 100644 --- a/bundles/org.openhab.binding.tapocontrol/src/main/java/org/openhab/binding/tapocontrol/internal/devices/wifi/lightstrip/TapoLightStripHandler.java +++ b/bundles/org.openhab.binding.tapocontrol/src/main/java/org/openhab/binding/tapocontrol/internal/devices/wifi/lightstrip/TapoLightStripHandler.java @@ -23,6 +23,7 @@ import org.openhab.core.library.types.HSBType; import org.openhab.core.library.types.OnOffType; import org.openhab.core.library.types.PercentType; +import org.openhab.core.library.types.QuantityType; import org.openhab.core.library.unit.Units; import org.openhab.core.thing.ChannelUID; import org.openhab.core.thing.Thing; @@ -43,7 +44,7 @@ public class TapoLightStripHandler extends TapoBaseDeviceHandler { /** * Constructor - * + * * @param thing Thing object representing device */ public TapoLightStripHandler(Thing thing) { @@ -53,7 +54,7 @@ public TapoLightStripHandler(Thing thing) { /** * Function called by {@link org.openhab.binding.tapocontrol.internal.api.TapoDeviceConnector} if new data were * received - * + * * @param queryCommand command where new data belong to */ @Override @@ -71,7 +72,7 @@ public void newDataResult(String queryCommand) { /** * handle command sent to device - * + * * @param channelUID channelUID command is sent to * @param command command to be sent */ @@ -128,8 +129,14 @@ private void handleColorCommand(Command command) { } private void handleColorTempCommand(Command command) { - if (command instanceof DecimalType decimalCommand) { - setColorTemp(decimalCommand.intValue()); + QuantityType kelvinQuantity = null; + if (command instanceof QuantityType genericQuantity) { + kelvinQuantity = genericQuantity.toInvertibleUnit(Units.KELVIN); + } else if (command instanceof DecimalType decimal) { + kelvinQuantity = QuantityType.valueOf(decimal.intValue(), Units.KELVIN); + } + if (kelvinQuantity != null) { + setColorTemp(kelvinQuantity.intValue()); } } @@ -164,7 +171,7 @@ private void handleLightFx(String channel, Command command) { /** * Switch device On or Off - * + * * @param on if true device will switch on. Otherwise switch off */ protected void switchOnOff(boolean on) { @@ -174,7 +181,7 @@ protected void switchOnOff(boolean on) { /** * Set Britghtness of device - * + * * @param newBrightness percentage 0-100 of new brightness */ protected void setBrightness(Integer newBrightness) { @@ -190,7 +197,7 @@ protected void setBrightness(Integer newBrightness) { /** * Set Color of Device - * + * * @param command HSBType */ protected void setColor(HSBType command) { @@ -203,7 +210,7 @@ protected void setColor(HSBType command) { /** * Set ColorTemp - * + * * @param colorTemp (Integer) in Kelvin */ protected void setColorTemp(Integer colorTemp) { @@ -214,7 +221,7 @@ protected void setColorTemp(Integer colorTemp) { /** * Set light effect - * + * * @param lightEffect TapoLightEffect */ protected void setLightEffect(TapoLightEffect lightEffect) {