diff --git a/bundles/org.openhab.binding.velbus/README.md b/bundles/org.openhab.binding.velbus/README.md index 001c2859bfc..d6ae71b34a0 100644 --- a/bundles/org.openhab.binding.velbus/README.md +++ b/bundles/org.openhab.binding.velbus/README.md @@ -152,18 +152,30 @@ OnOff command types are supported. For thing type `vmb4ry` 4 channels are available `CH1` ... `CH4`. OnOff command types are supported. -For thing types `vmb1ryno`, `vmb1rynos`, `vmb1rys`, `vmb4ryld` and `vmb4ryno` 5 channels are available `CH1` ... `CH5`. +For thing types `vmb1ryno`, `vmb1rynos`, `vmb4ryld` and `vmb4ryno` 5 channels are available `CH1` ... `CH5`. OnOff command types are supported. +For thing types `vmb1rys` 6 channels are available `CH1` ... `CH6`. +OnOff command types are supported on channels `CH1` ... `CH5`. +Pressed and Long_Pressed command types are supported on channel `CH6`. +1 trigger channel on `CH6t`. + The module `vmb1ts` has a number of channels to set the module's thermostat (`thermostat:currentTemperatureSetpoint`, `thermostat:heatingModeComfortTemperatureSetpoint`, `thermostat:heatingModeDayTemperatureSetpoint`, `thermostat:heatingModeNightTemperatureSetpoint`, `thermostat:heatingModeAntiFrostTemperatureSetpoint`, `thermostat:coolingModeComfortTemperatureSetpoint`, `thermostat:coolingModeDayTemperatureSetpoint`, `thermostat:coolingModeNightTemperatureSetpoint`, `thermostat:coolingModeSafeTemperatureSetpoint`, `operatingMode` and `thermostat:mode`) and thermostat trigger channels: `thermostat:heater`, `thermostat:boost`, `thermostat:pump`, `thermostat:cooler`, `thermostat:alarm1`, `thermostat:alarm2`, `thermostat:alarm3`, `thermostat:alarm4`. For thing types `vmb2bl` and `vmb2ble` the supported channels are `CH1` and `CH2`. UpDown, StopMove and Percent command types are supported. -Thing type `vmb6in` has 6 trigger channels `input#CH1` ... `input#CH6`. +For thing type `vmb6in` 6 channels are available `CH1` ... `CH6`. +Pressed and Long_Pressed command types are supported on channels `button#CH1` ... `button#CH6`. +6 trigger channels on channels `input#CH1` ... `input#CH6`. -Thing type `vmb7in` has 8 trigger channels `input#CH1` ... `input#CH8`. +For thing type `vmb7in` 8 channels are available `CH1` ... `CH8`. +Pressed and Long_Pressed command types are supported on channels `button#CH1` ... `button#CH8`. +8 trigger channels on channels `input#CH1` ... `input#CH8`. + +For thing types `vmb2pbn`, `vmb6pbn`, `vmb7in`, `vmb8ir`, `vmb8pb`, `vmb8pbu`, `vmbrfr8s` and `vmbvp1` 8 channels are available `CH1` ... `CH8`. +Pressed and Long_Pressed command types are supported on channels `button#CH1` ... `button#CH8`. +8 trigger channels on channels `input:CH1` ... `input:CH8`. -Thing types `vmb2pbn`, `vmb6pbn`, `vmb7in`, `vmb8ir`, `vmb8pb`, `vmb8pbu`, `vmbrfr8s` and `vmbvp1` have 8 trigger channels (`input:CH1` ... `input:CH8`). Thing types `vmb2pbn`, `vmb6pbn`, `vmb7in`, `vmb8pb`, `vmb8pbu`, `vmbrfr8s` and `vmbvp1` also have and 2 channels to steer the button LED feedback (`feedback:CH1` and `feedback:CH2`). Additionally, the modules `vmb2pbn`, `vmb6pbn`, `vmb7in`, `vmb8pbu`, `vmbrfr8s` and `vmbvp1` have a number of channels to set the module's alarms: `clockAlarm:clockAlarm1Enabled`, `clockAlarm:clockAlarm1Type`, `clockAlarm:clockAlarm1WakeupHour`, `clockAlarm:clockAlarm1WakeupMinute`, `clockAlarm:clockAlarm1BedtimeHour`, `clockAlarm:clockAlarm1BedtimeMinute`, `clockAlarm:clockAlarm2Enabled`, `clockAlarm:clockAlarm2Type`, `clockAlarm:clockAlarm2WakeupHour`, `clockAlarm:clockAlarm2WakeupMinute`, `clockAlarm:clockAlarm2BedtimeHour` and `clockAlarm:clockAlarm2BedtimeMinute`. @@ -181,6 +193,7 @@ For thing type `vmb4ry` 4 channels are available `CH1` ... `CH4`. OnOff command types are supported. Thing types `vmbel1`, `vmbel2`, `vmbel4`, `vmbgp1`, `vmbgp2`, `vmbgp4`, `vmbgp4pir` and `vmbpiro` have 8 trigger channels `input:CH1` ... `input:CH8` and one temperature channel `input:CH9`. +Pressed and Long_Pressed command types are supported on channels `button#CH1` ... `button#CH8`. The thing types `vmbel1` and `vmbgp1` have one channel to steer the button LED feedback `feedback:CH1`. The thing types `vmbel2` and `vmbgp2` have two channels to steer the button LED feedback `feedback:CH1` and `feedback:CH2`. The thing types `vmbel4`, `vmbgp4` and `vmbgp4pir` have four channels to steer the button LED feedback `feedback:CH1` ... `feedback:CH4`. @@ -189,6 +202,7 @@ Thing types `vmbel1`, `vmbel2`, `vmbel4`, `vmbgp1`, `vmbgp2`, `vmbgp4` and `vmbg Thing types `vmbel1`, `vmbel2`, `vmbel4`, `vmbgp1`, `vmbgp2`, `vmbgp4` and `vmbgp4pir` also have a number of channels to set the module's thermostat (`thermostat:currentTemperatureSetpoint`, `thermostat:heatingModeComfortTemperatureSetpoint`, `thermostat:heatingModeDayTemperatureSetpoint`, `thermostat:heatingModeNightTemperatureSetpoint`, `thermostat:heatingModeAntiFrostTemperatureSetpoint`, `thermostat:coolingModeComfortTemperatureSetpoint`, `thermostat:coolingModeDayTemperatureSetpoint`, `thermostat:coolingModeNightTemperatureSetpoint`, `thermostat:coolingModeSafeTemperatureSetpoint`, `operatingMode` and `thermostat:mode`) and thermostat trigger channels: `thermostat:heater`, `thermostat:boost`, `thermostat:pump`, `thermostat:cooler`, `thermostat:alarm1`, `thermostat:alarm2`, `thermostat:alarm3`, `thermostat:alarm4`. Thing types `vmbelo`, `vmbgpo` and `vmbgpod` have 32 trigger channels `input:CH1` ... `input:CH32` and one temperature channel `input:CH33`. +Pressed and Long_Pressed command types are supported on channels `button#CH1` ... `button#CH32`. They have have 32 channels to steer the button LED feedback `feedback:CH1` ... `feedback:CH32`. They have a number of channels to set the module's alarms: `clockAlarm:clockAlarm1Enabled`, `clockAlarm:clockAlarm1Type`, `clockAlarm:clockAlarm1WakeupHour`, `clockAlarm:clockAlarm1WakeupMinute`, `clockAlarm:clockAlarm1BedtimeHour`, `clockAlarm:clockAlarm1BedtimeMinute`, `clockAlarm:clockAlarm2Enabled`, `clockAlarm:clockAlarm2Type`, `clockAlarm:clockAlarm2WakeupHour`, `clockAlarm:clockAlarm2WakeupMinute`, `clockAlarm:clockAlarm2BedtimeHour` and `clockAlarm:clockAlarm2BedtimeMinute`. They have a number of channels to set the module's thermostat thermostat (`thermostat:currentTemperatureSetpoint`, `thermostat:heatingModeComfortTemperatureSetpoint`, `thermostat:heatingModeDayTemperatureSetpoint`, `thermostat:heatingModeNightTemperatureSetpoint`, `thermostat:heatingModeAntiFrostTemperatureSetpoint`, `thermostat:coolingModeComfortTemperatureSetpoint`, `thermostat:coolingModeDayTemperatureSetpoint`, `thermostat:coolingModeNightTemperatureSetpoint`, `thermostat:coolingModeSafeTemperatureSetpoint`, `operatingMode` and `thermostat:mode`) and thermostat trigger channels: `thermostat:heater`, `thermostat:boost`, `thermostat:pump`, `thermostat:cooler`, `thermostat:alarm1`, `thermostat:alarm2`, `thermostat:alarm3`, `thermostat:alarm4`. @@ -203,6 +217,9 @@ Additionally, these modules have a number of channels to set the module's alarms The trigger channels can be used as a trigger to rules. The event message can be `PRESSED`, `RELEASED`or `LONG_PRESSED`. +To remove the state of the Item in the Sitemap for a `button` channel. +Go to the Items list, select the Item, add a State Description Metadata, and set the Pattern value to a blank space. + ## Full Example .things: @@ -230,6 +247,7 @@ Bridge velbus:bridge:1 [ port="COM1"] { ``` Switch LivingRoom {channel="velbus:vmb4ryld:1:06:CH1"} # Switch for onOff type action +Switch KitchenButton {velbus:vmb2pbn:1:05:button#CH1} # Switch for Pressed and Long_Pressed type actions Dimmer TVRoom {channel="velbus:vmb4dc:1:07:CH2"} # Changing brightness dimmer type action Rollershutter Kitchen {channel="velbus:vmb2ble:1:01"} # Controlling rollershutter or blind type action @@ -245,6 +263,12 @@ Switch item=LivingRoom Slider item=TVRoom Switch item=TVRoom # allows switching dimmer item off or on Rollershutter item=Kitchen + +Switch item=KitchenButton # Press and Long_Pressed message are available +# or +Switch item=KitchenButton mappings=[PRESSED="Push"] # only the Pressed message is send on the bus +# or +Switch item=KitchenButton mappings=[LONG_PRESSED="Push"] # only the Long_Pressed message is send on the bus ``` Example trigger rule: diff --git a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/VelbusHandlerFactory.java b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/VelbusHandlerFactory.java index 8c7b1cdefb1..f603a205420 100644 --- a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/VelbusHandlerFactory.java +++ b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/VelbusHandlerFactory.java @@ -21,6 +21,7 @@ import org.openhab.binding.velbus.internal.handler.VelbusBridgeHandler; import org.openhab.binding.velbus.internal.handler.VelbusDimmerHandler; import org.openhab.binding.velbus.internal.handler.VelbusNetworkBridgeHandler; import org.openhab.binding.velbus.internal.handler.VelbusRelayHandler; +import org.openhab.binding.velbus.internal.handler.VelbusRelayWithInputHandler; import org.openhab.binding.velbus.internal.handler.VelbusSensorHandler; import org.openhab.binding.velbus.internal.handler.VelbusSensorWithAlarmClockHandler; import org.openhab.binding.velbus.internal.handler.VelbusSerialBridgeHandler; @@ -77,6 +78,8 @@ public class VelbusHandlerFactory extends BaseThingHandlerFactory { thingHandler = velbusBridgeHandler; } else if (VelbusRelayHandler.SUPPORTED_THING_TYPES.contains(thingTypeUID)) { thingHandler = new VelbusRelayHandler(thing); + } else if (VelbusRelayWithInputHandler.SUPPORTED_THING_TYPES.contains(thingTypeUID)) { + thingHandler = new VelbusRelayWithInputHandler(thing); } else if (VelbusDimmerHandler.SUPPORTED_THING_TYPES.contains(thingTypeUID)) { thingHandler = new VelbusDimmerHandler(thing); } else if (VelbusBlindsHandler.SUPPORTED_THING_TYPES.contains(thingTypeUID)) { diff --git a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/VelbusModule.java b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/VelbusModule.java index 49f9faa4b33..7037f3fcf5a 100644 --- a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/VelbusModule.java +++ b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/VelbusModule.java @@ -94,7 +94,7 @@ public class VelbusModule { protected String getChannelName(int channelIndex) { String channelName = ""; - Integer key = channelIndex - 1; + Integer key = channelIndex; if (channelNames.containsKey(key)) { for (int i = 0; i < 3; i++) { String channelNamePart = channelNames.get(key)[i]; @@ -147,7 +147,7 @@ public class VelbusModule { for (Integer key : keys) { String channelName = getChannelName(key); if (channelName.length() > 0) { - properties.put(CHANNEL + key, channelName); + properties.put(CHANNEL + (key + 1), channelName); } } diff --git a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/discovery/VelbusThingDiscoveryService.java b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/discovery/VelbusThingDiscoveryService.java index 417b8188685..65f32e9a6a4 100644 --- a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/discovery/VelbusThingDiscoveryService.java +++ b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/discovery/VelbusThingDiscoveryService.java @@ -32,7 +32,6 @@ import org.openhab.binding.velbus.internal.packets.VelbusScanPacket; import org.openhab.core.config.discovery.AbstractDiscoveryService; import org.openhab.core.config.discovery.DiscoveryResult; import org.openhab.core.config.discovery.DiscoveryResultBuilder; -import org.openhab.core.config.discovery.DiscoveryService; import org.openhab.core.thing.ThingUID; import org.openhab.core.thing.binding.ThingHandler; import org.openhab.core.thing.binding.ThingHandlerService; @@ -48,7 +47,7 @@ import org.slf4j.LoggerFactory; */ @NonNullByDefault public class VelbusThingDiscoveryService extends AbstractDiscoveryService - implements DiscoveryService, ThingHandlerService, VelbusPacketListener { + implements ThingHandlerService, VelbusPacketListener { private static final int SEARCH_TIME = 60; private final Logger logger = LoggerFactory.getLogger(VelbusThingDiscoveryService.class); diff --git a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusRelayHandler.java b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusRelayHandler.java index 196a775b952..9137fbe3636 100644 --- a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusRelayHandler.java +++ b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusRelayHandler.java @@ -40,9 +40,8 @@ import org.openhab.core.types.RefreshType; */ @NonNullByDefault public class VelbusRelayHandler extends VelbusThingHandler { - public static final Set SUPPORTED_THING_TYPES = new HashSet<>( - Arrays.asList(THING_TYPE_VMB1RY, THING_TYPE_VMB1RYNO, THING_TYPE_VMB1RYNOS, THING_TYPE_VMB1RYS, - THING_TYPE_VMB4RY, THING_TYPE_VMB4RYLD, THING_TYPE_VMB4RYNO)); + public static final Set SUPPORTED_THING_TYPES = new HashSet<>(Arrays.asList(THING_TYPE_VMB1RY, + THING_TYPE_VMB1RYNO, THING_TYPE_VMB1RYNOS, THING_TYPE_VMB4RY, THING_TYPE_VMB4RYLD, THING_TYPE_VMB4RYNO)); public VelbusRelayHandler(Thing thing) { super(thing, 0); diff --git a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusRelayWithInputHandler.java b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusRelayWithInputHandler.java new file mode 100644 index 00000000000..feca2dfd4df --- /dev/null +++ b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusRelayWithInputHandler.java @@ -0,0 +1,128 @@ +/** + * Copyright (c) 2010-2021 Contributors to the openHAB project + * + * See the NOTICE file(s) distributed with this work for additional + * information. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0 + * + * SPDX-License-Identifier: EPL-2.0 + */ +package org.openhab.binding.velbus.internal.handler; + +import static org.openhab.binding.velbus.internal.VelbusBindingConstants.*; + +import java.util.Arrays; +import java.util.HashSet; +import java.util.Set; + +import org.eclipse.jdt.annotation.NonNullByDefault; +import org.openhab.binding.velbus.internal.VelbusChannelIdentifier; +import org.openhab.binding.velbus.internal.packets.VelbusButtonPacket; +import org.openhab.binding.velbus.internal.packets.VelbusPacket; +import org.openhab.core.library.types.StringType; +import org.openhab.core.thing.ChannelUID; +import org.openhab.core.thing.CommonTriggerEvents; +import org.openhab.core.thing.Thing; +import org.openhab.core.thing.ThingStatus; +import org.openhab.core.thing.ThingStatusDetail; +import org.openhab.core.thing.ThingTypeUID; +import org.openhab.core.types.Command; + +/** + * The {@link VelbusRelayWithInputHandler} is responsible for handling commands, which are + * sent to one of the channels. + * + * @author Daniel Rosengarten - Initial contribution + */ +@NonNullByDefault +public class VelbusRelayWithInputHandler extends VelbusRelayHandler { + public static final Set SUPPORTED_THING_TYPES = new HashSet<>(Arrays.asList(THING_TYPE_VMB1RYS)); + + private static final StringType PRESSED = new StringType("PRESSED"); + private static final StringType LONG_PRESSED = new StringType("LONG_PRESSED"); + + public VelbusRelayWithInputHandler(Thing thing) { + super(thing); + } + + @Override + public void handleCommand(ChannelUID channelUID, Command command) { + super.handleCommand(channelUID, command); + + VelbusBridgeHandler velbusBridgeHandler = getVelbusBridgeHandler(); + if (velbusBridgeHandler == null) { + updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.BRIDGE_OFFLINE); + return; + } + + if (isButtonChannel(channelUID) && command instanceof StringType) { + StringType stringTypeCommand = (StringType) command; + + if (stringTypeCommand.equals(PRESSED) || stringTypeCommand.equals(LONG_PRESSED)) { + VelbusButtonPacket packet = new VelbusButtonPacket(getModuleAddress().getChannelIdentifier(channelUID)); + + packet.Pressed(); + velbusBridgeHandler.sendPacket(packet.getBytes()); + triggerChannel("CH6t", CommonTriggerEvents.PRESSED); + + if (stringTypeCommand.equals(LONG_PRESSED)) { + packet.LongPressed(); + velbusBridgeHandler.sendPacket(packet.getBytes()); + triggerChannel("CH6t", CommonTriggerEvents.LONG_PRESSED); + } + + packet.Released(); + velbusBridgeHandler.sendPacket(packet.getBytes()); + triggerChannel("CH6t", CommonTriggerEvents.RELEASED); + } else { + throw new UnsupportedOperationException( + "The command '" + command + "' is not supported on channel '" + channelUID + "'."); + } + } + } + + private boolean isButtonChannel(ChannelUID channelUID) { + return "CH6".equals(channelUID.toString().substring(channelUID.toString().length() - 3)); + } + + private boolean isTriggerChannel(byte address, byte channel) { + VelbusChannelIdentifier velbusChannelIdentifier = new VelbusChannelIdentifier(address, channel); + + if (getModuleAddress().getChannelNumber(velbusChannelIdentifier) == 6) { + return true; + } else { + return false; + } + } + + @Override + public void onPacketReceived(byte[] packet) { + super.onPacketReceived(packet); + + if (packet[0] == VelbusPacket.STX && packet.length >= 5) { + byte command = packet[4]; + + if (command == COMMAND_PUSH_BUTTON_STATUS && packet.length >= 6) { + byte address = packet[2]; + + byte channelJustPressed = packet[5]; + if (isTriggerChannel(address, channelJustPressed)) { + triggerChannel("CH6t", CommonTriggerEvents.PRESSED); + } + + byte channelJustReleased = packet[6]; + if (isTriggerChannel(address, channelJustReleased)) { + triggerChannel("CH6t", CommonTriggerEvents.RELEASED); + } + + byte channelLongPressed = packet[7]; + if (isTriggerChannel(address, channelLongPressed)) { + triggerChannel("CH6t", CommonTriggerEvents.LONG_PRESSED); + } + } + } + } +} diff --git a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusSensorHandler.java b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusSensorHandler.java index aa7c13f9fbe..852625925b4 100644 --- a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusSensorHandler.java +++ b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/handler/VelbusSensorHandler.java @@ -20,6 +20,7 @@ import java.util.Set; import org.eclipse.jdt.annotation.NonNullByDefault; import org.openhab.binding.velbus.internal.VelbusChannelIdentifier; +import org.openhab.binding.velbus.internal.packets.VelbusButtonPacket; import org.openhab.binding.velbus.internal.packets.VelbusFeedbackLEDPacket; import org.openhab.binding.velbus.internal.packets.VelbusPacket; import org.openhab.core.library.types.StringType; @@ -36,6 +37,7 @@ import org.openhab.core.types.Command; * sent to one of the channels. * * @author Cedric Boon - Initial contribution + * @author Daniel Rosengarten - Add button simulation */ @NonNullByDefault public class VelbusSensorHandler extends VelbusThingHandler { @@ -48,6 +50,9 @@ public class VelbusSensorHandler extends VelbusThingHandler { private static final StringType VERY_FAST_BLINK_LED = new StringType("VERY_FAST_BLINK_LED"); private static final StringType CLEAR_LED = new StringType("CLEAR_LED"); + private static final StringType PRESSED = new StringType("PRESSED"); + private static final StringType LONG_PRESSED = new StringType("LONG_PRESSED"); + public VelbusSensorHandler(Thing thing) { this(thing, 0); } @@ -89,12 +94,44 @@ public class VelbusSensorHandler extends VelbusThingHandler { byte[] packetBytes = packet.getBytes(); velbusBridgeHandler.sendPacket(packetBytes); } + + if (isButtonChannel(channelUID) && command instanceof StringType) { + StringType stringTypeCommand = (StringType) command; + + if (stringTypeCommand.equals(PRESSED) || stringTypeCommand.equals(LONG_PRESSED)) { + VelbusButtonPacket packet = new VelbusButtonPacket(getModuleAddress().getChannelIdentifier(channelUID)); + + packet.Pressed(); + velbusBridgeHandler.sendPacket(packet.getBytes()); + triggerChannel("input#CH" + getModuleAddress().getChannelNumber(channelUID), + CommonTriggerEvents.PRESSED); + + if (stringTypeCommand.equals(LONG_PRESSED)) { + packet.LongPressed(); + velbusBridgeHandler.sendPacket(packet.getBytes()); + triggerChannel("input#CH" + getModuleAddress().getChannelNumber(channelUID), + CommonTriggerEvents.LONG_PRESSED); + } + + packet.Released(); + velbusBridgeHandler.sendPacket(packet.getBytes()); + triggerChannel("input#CH" + getModuleAddress().getChannelNumber(channelUID), + CommonTriggerEvents.RELEASED); + } else { + throw new UnsupportedOperationException( + "The command '" + command + "' is not supported on channel '" + channelUID + "'."); + } + } } private boolean isFeedbackChannel(ChannelUID channelUID) { return "feedback".equals(channelUID.getGroupId()); } + private boolean isButtonChannel(ChannelUID channelUID) { + return "button".equals(channelUID.getGroupId()); + } + @Override public void onPacketReceived(byte[] packet) { logger.trace("onPacketReceived() was called"); diff --git a/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/packets/VelbusButtonPacket.java b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/packets/VelbusButtonPacket.java new file mode 100644 index 00000000000..11cccee35b1 --- /dev/null +++ b/bundles/org.openhab.binding.velbus/src/main/java/org/openhab/binding/velbus/internal/packets/VelbusButtonPacket.java @@ -0,0 +1,54 @@ +/** + * Copyright (c) 2010-2021 Contributors to the openHAB project + * + * See the NOTICE file(s) distributed with this work for additional + * information. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0 + * + * SPDX-License-Identifier: EPL-2.0 + */ +package org.openhab.binding.velbus.internal.packets; + +import org.eclipse.jdt.annotation.NonNullByDefault; +import org.openhab.binding.velbus.internal.VelbusBindingConstants; +import org.openhab.binding.velbus.internal.VelbusChannelIdentifier; + +/** + * The {@link VelbusButtonPacket} represents a Velbus packet that can be used to + * simulate a pushed button. + * + * @author Daniel Rosengarten - Initial contribution + */ +@NonNullByDefault +public class VelbusButtonPacket extends VelbusPacket { + private byte channel; + private byte[] data; + + public VelbusButtonPacket(VelbusChannelIdentifier velbusChannelIdentifier) { + super(velbusChannelIdentifier.getAddress(), PRIO_HI, false); + + this.channel = velbusChannelIdentifier.getChannelByte(); + this.data = new byte[] { VelbusBindingConstants.COMMAND_PUSH_BUTTON_STATUS, (byte) 0x00, (byte) 0x00, + (byte) 0x00 }; + } + + public void Pressed() { + data = new byte[] { VelbusBindingConstants.COMMAND_PUSH_BUTTON_STATUS, channel, (byte) 0x00, (byte) 0x00 }; + } + + public void LongPressed() { + data = new byte[] { VelbusBindingConstants.COMMAND_PUSH_BUTTON_STATUS, (byte) 0x00, (byte) 0x00, channel }; + } + + public void Released() { + data = new byte[] { VelbusBindingConstants.COMMAND_PUSH_BUTTON_STATUS, (byte) 0x00, channel, (byte) 0x00 }; + } + + @Override + protected byte[] getDataBytes() { + return data; + } +} diff --git a/bundles/org.openhab.binding.velbus/src/main/resources/OH-INF/thing/thing-types.xml b/bundles/org.openhab.binding.velbus/src/main/resources/OH-INF/thing/thing-types.xml index cf6b6133b81..e754617dfa7 100644 --- a/bundles/org.openhab.binding.velbus/src/main/resources/OH-INF/thing/thing-types.xml +++ b/bundles/org.openhab.binding.velbus/src/main/resources/OH-INF/thing/thing-types.xml @@ -136,16 +136,18 @@ - 1-channel relay module + 1-channel relay module with input + + - + @@ -206,6 +208,7 @@ Push-button interface for Niko 1- or 2-fold push-buttons + @@ -313,6 +316,7 @@ 6-channel input module + @@ -328,6 +332,7 @@ Push-button interface module for Niko 4- or 6-fold push-button + @@ -345,6 +350,7 @@ 7-channel input module (potentialfree + pulse) + @@ -362,6 +368,7 @@ Infrared remote control receiver module + @@ -377,6 +384,7 @@ 8-Channel Push Button module + @@ -393,6 +401,7 @@ Push-button interface with 8 channels for universal mounting + @@ -455,6 +464,7 @@ Edge-lit one touch button module + @@ -473,6 +483,7 @@ Edge-lit two touch buttons module + @@ -491,6 +502,7 @@ Edge-lit four touch buttons module + @@ -509,6 +521,7 @@ Edge-lit touch panel with Oled display + @@ -528,6 +541,7 @@ Glass control module with 1 touch key + @@ -546,6 +560,7 @@ Glass control module with 1 touch key (Edition 2) + @@ -564,6 +579,7 @@ Glass control module with 2 touch keys + @@ -582,6 +598,7 @@ Glass control module with 2 touch keys (Edition 2) + @@ -600,6 +617,7 @@ Glass control module with 4 touch keys + @@ -618,6 +636,7 @@ Glass control module with 4 touch keys (Edition 2) + @@ -636,6 +655,7 @@ Glass control module with 4 touch keys and built-in motion and twilight sensor + @@ -654,6 +674,7 @@ Glass control module with 4 touch keys and built-in motion and twilight sensor (Edition 2) + @@ -672,6 +693,7 @@ Glass control module with oled display + @@ -691,6 +713,7 @@ Glass control module with oled display and temperature controller + @@ -710,6 +733,7 @@ Glass control module with oled display and temperature controller (Edition 2) + @@ -877,6 +901,17 @@ Switch control for action in Velbus Switch + + String + + Switch + + + + + + + Dimmer @@ -1257,6 +1292,76 @@ + + + + This is a generic module with 6 button channels. + + + + + + + + + + + + + + This is a generic module with 8 button channels. + + + + + + + + + + + + + + + + This is a generic module with 32 button channels. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +