mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
[deconz] add ontime feature (#9914)
* add ontime Signed-off-by: Jan N. Klug <jan.n.klug@rub.de> * Update bundles/org.openhab.binding.deconz/README.md Co-authored-by: Fabian Wolter <github@fabian-wolter.de> Co-authored-by: Fabian Wolter <github@fabian-wolter.de>
This commit is contained in:
parent
3f13392180
commit
1c0da8367e
@ -170,6 +170,7 @@ Other devices support
|
|||||||
| effect | String | R/W | Effect selection. Allowed commands are set dynamically | `colorlight` |
|
| effect | String | R/W | Effect selection. Allowed commands are set dynamically | `colorlight` |
|
||||||
| effectSpeed | Number | W | Effect Speed | `colorlight` |
|
| effectSpeed | Number | W | Effect Speed | `colorlight` |
|
||||||
| lock | Switch | R/W | Lock (ON) or unlock (OFF) the doorlock| `doorlock` |
|
| lock | Switch | R/W | Lock (ON) or unlock (OFF) the doorlock| `doorlock` |
|
||||||
|
| ontime | Number:Time | W | Timespan for which the light is turned on | all lights |
|
||||||
| position | Rollershutter | R/W | Position of the blind | `windowcovering` |
|
| position | Rollershutter | R/W | Position of the blind | `windowcovering` |
|
||||||
| heatsetpoint | Number:Temperature | R/W | Target Temperature in °C | `thermostat` |
|
| heatsetpoint | Number:Temperature | R/W | Target Temperature in °C | `thermostat` |
|
||||||
| valve | Number:Dimensionless | R | Valve position in % | `thermostat` |
|
| valve | Number:Dimensionless | R | Valve position in % | `thermostat` |
|
||||||
|
@ -118,6 +118,7 @@ public class BindingConstants {
|
|||||||
public static final String CHANNEL_EFFECT = "effect";
|
public static final String CHANNEL_EFFECT = "effect";
|
||||||
public static final String CHANNEL_EFFECT_SPEED = "effectSpeed";
|
public static final String CHANNEL_EFFECT_SPEED = "effectSpeed";
|
||||||
public static final String CHANNEL_SCENE = "scene";
|
public static final String CHANNEL_SCENE = "scene";
|
||||||
|
public static final String CHANNEL_ONTIME = "ontime";
|
||||||
|
|
||||||
// channel uids
|
// channel uids
|
||||||
public static final ChannelTypeUID CHANNEL_EFFECT_TYPE_UID = new ChannelTypeUID(BINDING_ID, CHANNEL_EFFECT);
|
public static final ChannelTypeUID CHANNEL_EFFECT_TYPE_UID = new ChannelTypeUID(BINDING_ID, CHANNEL_EFFECT);
|
||||||
|
@ -36,6 +36,7 @@ public class LightState {
|
|||||||
public @Nullable String colormode;
|
public @Nullable String colormode;
|
||||||
public @Nullable String effect;
|
public @Nullable String effect;
|
||||||
public @Nullable Integer effectSpeed;
|
public @Nullable Integer effectSpeed;
|
||||||
|
public @Nullable Integer ontime;
|
||||||
|
|
||||||
// depending on the type of light
|
// depending on the type of light
|
||||||
public @Nullable Integer hue;
|
public @Nullable Integer hue;
|
||||||
@ -68,6 +69,7 @@ public class LightState {
|
|||||||
colormode = null;
|
colormode = null;
|
||||||
effect = null;
|
effect = null;
|
||||||
effectSpeed = null;
|
effectSpeed = null;
|
||||||
|
ontime = null;
|
||||||
|
|
||||||
hue = null;
|
hue = null;
|
||||||
sat = null;
|
sat = null;
|
||||||
@ -85,7 +87,7 @@ public class LightState {
|
|||||||
public String toString() {
|
public String toString() {
|
||||||
return "LightState{" + "reachable=" + reachable + ", on=" + on + ", bri=" + bri + ", alert='" + alert + '\''
|
return "LightState{" + "reachable=" + reachable + ", on=" + on + ", bri=" + bri + ", alert='" + alert + '\''
|
||||||
+ ", colormode='" + colormode + '\'' + ", effect='" + effect + '\'' + ", effectSpeed=" + effectSpeed
|
+ ", colormode='" + colormode + '\'' + ", effect='" + effect + '\'' + ", effectSpeed=" + effectSpeed
|
||||||
+ ", hue=" + hue + ", sat=" + sat + ", ct=" + ct + ", xy=" + Arrays.toString(xy) + ", transitiontime="
|
+ ", ontime=" + ontime + ", hue=" + hue + ", sat=" + sat + ", ct=" + ct + ", xy=" + Arrays.toString(xy)
|
||||||
+ transitiontime + '}';
|
+ ", transitiontime=" + transitiontime + '}';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,7 @@ import org.openhab.binding.deconz.internal.dto.LightMessage;
|
|||||||
import org.openhab.binding.deconz.internal.dto.LightState;
|
import org.openhab.binding.deconz.internal.dto.LightState;
|
||||||
import org.openhab.binding.deconz.internal.types.ResourceType;
|
import org.openhab.binding.deconz.internal.types.ResourceType;
|
||||||
import org.openhab.core.library.types.*;
|
import org.openhab.core.library.types.*;
|
||||||
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.thing.ChannelUID;
|
import org.openhab.core.thing.ChannelUID;
|
||||||
import org.openhab.core.thing.Thing;
|
import org.openhab.core.thing.Thing;
|
||||||
import org.openhab.core.thing.ThingStatus;
|
import org.openhab.core.thing.ThingStatus;
|
||||||
@ -78,6 +79,7 @@ public class LightThingHandler extends DeconzBaseThingHandler {
|
|||||||
*/
|
*/
|
||||||
private LightState lightStateCache = new LightState();
|
private LightState lightStateCache = new LightState();
|
||||||
private LightState lastCommand = new LightState();
|
private LightState lastCommand = new LightState();
|
||||||
|
private int onTime = 0; // in 0.1s
|
||||||
private String colorMode = "";
|
private String colorMode = "";
|
||||||
|
|
||||||
// set defaults, we can override them later if we receive better values
|
// set defaults, we can override them later if we receive better values
|
||||||
@ -124,6 +126,19 @@ public class LightThingHandler extends DeconzBaseThingHandler {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handleCommand(ChannelUID channelUID, Command command) {
|
public void handleCommand(ChannelUID channelUID, Command command) {
|
||||||
|
if (channelUID.getId().equals(CHANNEL_ONTIME)) {
|
||||||
|
if (command instanceof QuantityType<?>) {
|
||||||
|
QuantityType<?> onTimeSeconds = ((QuantityType<?>) command).toUnit(Units.SECOND);
|
||||||
|
if (onTimeSeconds != null) {
|
||||||
|
onTime = 10 * onTimeSeconds.intValue();
|
||||||
|
} else {
|
||||||
|
logger.warn("Channel '{}' received command '{}', could not be converted to seconds.", channelUID,
|
||||||
|
command);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (command instanceof RefreshType) {
|
if (command instanceof RefreshType) {
|
||||||
valueUpdated(channelUID.getId(), lightStateCache);
|
valueUpdated(channelUID.getId(), lightStateCache);
|
||||||
return;
|
return;
|
||||||
@ -255,6 +270,8 @@ public class LightThingHandler extends DeconzBaseThingHandler {
|
|||||||
// if light shall be off, no other commands are allowed, so reset the new light state
|
// if light shall be off, no other commands are allowed, so reset the new light state
|
||||||
newLightState.clear();
|
newLightState.clear();
|
||||||
newLightState.on = false;
|
newLightState.on = false;
|
||||||
|
} else if (newOn != null && newOn) {
|
||||||
|
newLightState.ontime = onTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
sendCommand(newLightState, command, channelUID, () -> {
|
sendCommand(newLightState, command, channelUID, () -> {
|
||||||
|
@ -44,6 +44,7 @@
|
|||||||
<description>A light that can be turned on or off.</description>
|
<description>A light that can be turned on or off.</description>
|
||||||
<channels>
|
<channels>
|
||||||
<channel typeId="onoff" id="switch"/>
|
<channel typeId="onoff" id="switch"/>
|
||||||
|
<channel typeId="ontime" id="ontime"/>
|
||||||
</channels>
|
</channels>
|
||||||
|
|
||||||
<representation-property>uid</representation-property>
|
<representation-property>uid</representation-property>
|
||||||
@ -60,6 +61,7 @@
|
|||||||
<category>Lightbulb</category>
|
<category>Lightbulb</category>
|
||||||
<channels>
|
<channels>
|
||||||
<channel typeId="brightness" id="brightness"/>
|
<channel typeId="brightness" id="brightness"/>
|
||||||
|
<channel typeId="ontime" id="ontime"/>
|
||||||
<channel id="alert" typeId="alert"></channel>
|
<channel id="alert" typeId="alert"></channel>
|
||||||
</channels>
|
</channels>
|
||||||
|
|
||||||
@ -78,6 +80,7 @@
|
|||||||
<channels>
|
<channels>
|
||||||
<channel typeId="brightness" id="brightness"/>
|
<channel typeId="brightness" id="brightness"/>
|
||||||
<channel typeId="ct" id="color_temperature"/>
|
<channel typeId="ct" id="color_temperature"/>
|
||||||
|
<channel typeId="ontime" id="ontime"/>
|
||||||
<channel id="alert" typeId="alert"></channel>
|
<channel id="alert" typeId="alert"></channel>
|
||||||
</channels>
|
</channels>
|
||||||
|
|
||||||
@ -95,6 +98,7 @@
|
|||||||
<category>Lightbulb</category>
|
<category>Lightbulb</category>
|
||||||
<channels>
|
<channels>
|
||||||
<channel typeId="color" id="color"/>
|
<channel typeId="color" id="color"/>
|
||||||
|
<channel typeId="ontime" id="ontime"/>
|
||||||
<channel id="alert" typeId="alert"></channel>
|
<channel id="alert" typeId="alert"></channel>
|
||||||
</channels>
|
</channels>
|
||||||
|
|
||||||
@ -113,6 +117,7 @@
|
|||||||
<channels>
|
<channels>
|
||||||
<channel typeId="color" id="color"/>
|
<channel typeId="color" id="color"/>
|
||||||
<channel typeId="ct" id="color_temperature"/>
|
<channel typeId="ct" id="color_temperature"/>
|
||||||
|
<channel typeId="ontime" id="ontime"/>
|
||||||
<channel id="alert" typeId="alert"></channel>
|
<channel id="alert" typeId="alert"></channel>
|
||||||
</channels>
|
</channels>
|
||||||
|
|
||||||
@ -181,6 +186,12 @@
|
|||||||
<state pattern="%d K" min="15" max="100000" step="100"/>
|
<state pattern="%d K" min="15" max="100000" step="100"/>
|
||||||
</channel-type>
|
</channel-type>
|
||||||
|
|
||||||
|
<channel-type id="ontime">
|
||||||
|
<item-type>Number:Time</item-type>
|
||||||
|
<label>On Time</label>
|
||||||
|
<description>Time that the light stays on before switched off automatically (0=forever)</description>
|
||||||
|
</channel-type>
|
||||||
|
|
||||||
<channel-type id="effect">
|
<channel-type id="effect">
|
||||||
<item-type>String</item-type>
|
<item-type>String</item-type>
|
||||||
<label>Effect Channel</label>
|
<label>Effect Channel</label>
|
||||||
|
Loading…
Reference in New Issue
Block a user