From 06d8e750f24ca6892190701b9a8f92044f39474a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marco=20M=C3=BCller?= Date: Tue, 10 Oct 2023 09:58:49 +0200 Subject: [PATCH] [knx] Bugfix problem with DPT 251.600 (#15723) * Fix problem with DPT 251.600. In the old implementation the datatype was implemented with byte 0-255. The DPT 251.600 is defined with 0-100%, change this from byte to PercentType. Signed-off-by: Marco Mueller --- .../org/openhab/binding/knx/internal/dpt/ValueEncoder.java | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/bundles/org.openhab.binding.knx/src/main/java/org/openhab/binding/knx/internal/dpt/ValueEncoder.java b/bundles/org.openhab.binding.knx/src/main/java/org/openhab/binding/knx/internal/dpt/ValueEncoder.java index f30a137d0..c2519d3bf 100644 --- a/bundles/org.openhab.binding.knx/src/main/java/org/openhab/binding/knx/internal/dpt/ValueEncoder.java +++ b/bundles/org.openhab.binding.knx/src/main/java/org/openhab/binding/knx/internal/dpt/ValueEncoder.java @@ -162,8 +162,9 @@ public class ValueEncoder { double[] xyY = ColorUtil.hsbToXY(hsb); return String.format("(%,.4f %,.4f) %,.1f %%", xyY[0], xyY[1], xyY[2] * 100.0); case "251.600": - rgb = ColorUtil.hsbToRgb(hsb); - return String.format("%d %d %d - %%", rgb[0], rgb[1], rgb[2]); + PercentType[] rgbw = ColorUtil.hsbToRgbPercent(hsb); + return String.format("%,.1f %,.1f %,.1f - %%", rgbw[0].doubleValue(), rgbw[1].doubleValue(), + rgbw[2].doubleValue()); case "5.003": return hsb.getHue().toString(); default: