NEWS
Colorpicker für dicke Finger
-
Hi,
ich versuche meine LED (RGB) anzusteuern. Allerdings sind die Colorpicker Widgets für die Bedienung am Wandtablett nur bedingt geeignet. Die Fläche die sich öffnet ist für die Bedienung mit dem Finger viel zu klein. Was gut aussieht ist das Phillips HUE xy-Picker Widget. Den kann man beliebig groß ziehen. Damit kann ich allerdings keine RGB-LEDs ansteuern. Da ich von HUE keine Ahnung habe, würde ich gerne wissen, ob ich den xy-Wert des HUE in ein Datenpunkt schreiben kann. Als String hat es nicht geklappt. Dann könnte ich mit einem Script die Umrechnung in RGB durchführen.
Oder gibt es sogar einen anderen Colorpicker, den man ähnlich wie den HUE nutzen kann?
Danke, a200.
-
ich weiß nicht, ob dir das hilft...
ich habe mit einen selbergebaut, es ist kein "vollwertiger" Colorpicker, er enthält nur die Grundfarben...
Das sind einfach bunte Buttons, die den ensprechenden Wert in den DP der Lampe schreiben. Funktioniert problemlos, ließe sich natürlich um beliebig viele Buttons erweitern, aber ist natürlich kein echtes RGB
-
@supermicha Vielen Dank. Das war mein "Plan B". Ich bin überrascht, dass die LED Steuerung über ein Tablett so wenig Beachtung hier findet. Ich bin mir sicher, dass es bessere Lösungen gibt.
-
Ja, ein echter RGB-Colorpicker stand auch lange auf meiner Wunschliste...
Das sollte ja grundsätzlich nicht sooo schwer sein, ist ja in praktisch jeder Smart-Home/Smart-Lightning-App zu finden...
Wobei ich mittlerweile finde, das mir die Grundfarben in meiner Umsetzung eigentlich ausreichen, grade wenn man verschiedene Lampen gleichfarbig schalten will, wird es schwierig mehrfach den exakten Farbton aus nem Colorpicker rauszuholen. Da sind Presets doch recht hilfreich...
In der Praxis hat man ja meist ein eine handvoll Grundtöne, die man immer wieder verwendet.Also selbst wenn es einen vernünftigen Colorpicker geben würde, wäre das bei mir sicherlich nur noch eine optionale Komponente... das einfache steuern über ein paar Buttons erscheint mir mittlerweile komfortalber als die Variante jede Farbe aus 65tausend Tönen wählen zu müssen.
Und wenn mir ein Ton in den Presets nicht mehr gefällt, änder ich einfach den Button.
-
-
das wusste ich auch noch nicht...
-
@liv-in-sky Stimmt, das ist eine gute Idee. Auch wenn mir nur der Farbenring vollkommen reichen würde. Danke!
-
leg doch ein image über den Mittelteil den du nicht brauchst...
oder sinnvollerweise vielleicht einen Ein/Aus-Button
oder ein paar Preset-Buttons mit Lieblingstönen... -
@supermicha Hab ich gemacht. Der Tipp mit dem Colorpicker von @liv-in-sky war Gold wert.
Das Feld mit dem LED-Stripe ist der "Schalter". Sind die LEDs an, dann zeigt die Farbe um den Schalter herum die aktuelle Farbe an.
LED ist an
LED ist aus
Wird der Schalter angeklickt erscheint ein Dialog:
Farbring: Farbauswahl
Innerer Ring: Helligkeit. Dabei wird die jeweils aktuelle Farbe verwendet.
Kleiner Kreis: Ein/Aus KnopfGesamteindruck
Meine einzige Sorge ist, wenn der Colorpicker in der Mitte, also das verdeckte Viereck, einen falschen Wert erhält, dann habe ich kaum eine Möglichkeit diesen zu ändern. Da muss ich mir noch was einfallen lassen.
-
Wo wir gerade bei coolen Colorpickern sind, möchte ich euch den hier nicht vorenthalten, gerade auf einem Wandtablet ist ein runder Colorpicker nicht wirklich ergonomisch:
Dieser besteht aus einem vis-materialdesign Slider mit dem RGB als hintergrund:[{"tpl":"_tplGroup","data":{"members":["w00957","w00958"],"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","attrCount":"1","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"attrName1":"Objekt-ID","attrType1":"id","groupAttr1":"0_userdata.0.Vis_Slider.Slider_8"},"style":{"top":"144px","left":"13px","width":"804px","height":"25px","z-index":"10"},"widgetSet":null},{"tpl":"tplImage","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":true,"g_css_border":true,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"0","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"src":""},"style":{"left":"0%","top":"0%","width":"97.89%","height":"100%","border-radius":"5px","box-shadow":"1","z-index":"10"},"widgetSet":"basic","grouped":true,"groupName":"w00957"},{"tpl":"tplVis-materialdesign-Vuetify-Slider","data":{"oid":"groupAttr1","g_fixed":false,"g_visibility":false,"g_css_font_text":true,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","orientation":"horizontal","knobSize":"knobBig","step":"1","vibrateOnMobilDevices":"50","showTicks":"yes","tickTextColor":"{mode:vis-materialdesign.0.colors.darkTheme;light:vis-materialdesign.0.colors.light.slider.tick;dark:vis-materialdesign.0.colors.dark.slider.tick; mode === \"true\" ? dark : light}","tickFontFamily":"{vis-materialdesign.0.fonts.slider.ticks}","tickFontSize":"{vis-materialdesign.0.fontSizes.slider.ticks}","tickColorBefore":"{mode:vis-materialdesign.0.colors.darkTheme;light:vis-materialdesign.0.colors.light.slider.tick_before;dark:vis-materialdesign.0.colors.dark.slider.tick_before; mode === \"true\" ? dark : light}","tickColorAfter":"{mode:vis-materialdesign.0.colors.darkTheme;light:vis-materialdesign.0.colors.light.slider.tick_after;dark:vis-materialdesign.0.colors.dark.slider.tick_after; mode === \"true\" ? dark : light}","colorBeforeThumb":"#c2c2c200","colorThumb":"#21212100","colorAfterThumb":"#21212100","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"g_thumbLabelLayout":true,"showThumbLabel":"always","thumbBackgroundColor":"#ffffff","thumbFontColor":"","thumbFontSize":"0","thumbFontFamily":"{vis-materialdesign.0.fonts.slider.control}","g_label":true,"prepandTextColor":"{mode:vis-materialdesign.0.colors.darkTheme;light:vis-materialdesign.0.colors.light.slider.text_prepand;dark:vis-materialdesign.0.colors.dark.slider.text_prepand; mode === \"true\" ? dark : light}","prepandTextFontSize":"{vis-materialdesign.0.fontSizes.slider.prepand}","prepandTextFontFamily":"{vis-materialdesign.0.fonts.slider.prepand}","showValueLabel":false,"valueLabelStyle":"sliderValue","valueFontFamily":"{vis-materialdesign.0.fonts.slider.value}","valueFontSize":"{vis-materialdesign.0.fontSizes.slider.value}","valueLabelColor":"{mode:vis-materialdesign.0.colors.darkTheme;light:vis-materialdesign.0.colors.light.slider.text;dark:vis-materialdesign.0.colors.dark.slider.text; mode === \"true\" ? dark : light}","valueLabelWidth":"50","reverseSlider":false,"thumbSize":"15","readOnly":false,"useLabelRules":false,"min":"0","max":"1530"},"style":{"left":"1.12%","top":"0%","width":"98.88%","height":"100%","z-index":"11","font-size":"xx-small"},"widgetSet":"materialdesign","grouped":true,"groupName":"w00958"}]
Der Wert zwischen 1 und 1530 wird anschließend in einen Datenpunkt geschrieben und von einem kleinen Node-Red Flow ausgewertet:
[ { "id": "999a393e.f3ecd8", "type": "ioBroker in", "z": "2faf5f0b.6de9e", "name": "", "topic": "0_userdata.0.Vis_Slider.Slider_2", "payloadType": "value", "onlyack": "", "func": "all", "gap": "", "fireOnStart": "false", "x": 170, "y": 280, "wires": [ [ "6f338ec1.c7fef8" ] ] }, { "id": "6f338ec1.c7fef8", "type": "function", "z": "2faf5f0b.6de9e", "name": "", "func": "msg.payload = parseInt(msg.payload)\nreturn msg;", "outputs": 1, "noerr": 0, "initialize": "", "finalize": "", "libs": [], "x": 430, "y": 280, "wires": [ [ "e9164d83.21a128", "f5eeab30.337e28", "2d3e7fc0.bbffd8" ] ] }, { "id": "f5eeab30.337e28", "type": "function", "z": "2faf5f0b.6de9e", "name": "G", "func": "if(msg.payload < 256){\n \nmsg.out = msg.payload\n\n}\n\nif(msg.payload >= 256 && msg.payload < 512){\n \nmsg.out = 255\n\n}\n\nif(msg.payload >= 512 && msg.payload < 766){\n \nmsg.out = 255\n}\n\nif(msg.payload >= 1020 ){\n \nmsg.out = 0\n}\n\nif(msg.payload >= 766 && msg.payload < 1020){\n \nmsg.out = 255 - (msg.payload-765)\n \n}\nreturn msg;", "outputs": 1, "noerr": 0, "initialize": "", "finalize": "", "x": 600, "y": 280, "wires": [ [ "fa96e0aa.7c" ] ] }, { "id": "e9164d83.21a128", "type": "function", "z": "2faf5f0b.6de9e", "name": "R", "func": "if(msg.payload >= 256 && msg.payload <= 510){\n \nmsg.out = 255 - (msg.payload-255)\n\n}\n\nif(msg.payload >= 1021 && msg.payload <= 1275){\n \nmsg.out = (msg.payload-1020)\n\n}\n\nif(msg.payload < 256){\n\n msg.out = 255\n}\n\nif(msg.payload > 1275){\n\n msg.out = 255\n}\n\nif(msg.payload > 510 && msg.payload < 1021){\n \nmsg.out = 0\n}\n\n\nreturn msg;", "outputs": 1, "noerr": 0, "initialize": "", "finalize": "", "libs": [], "x": 600, "y": 240, "wires": [ [ "60867af.c83e284" ] ] }, { "id": "2d3e7fc0.bbffd8", "type": "function", "z": "2faf5f0b.6de9e", "name": "B", "func": "if(msg.payload >= 511 && msg.payload < 765){\n \nmsg.out = (msg.payload-510)\n}\n\nif(msg.payload > 1275 ){\n \nmsg.out = 255- (msg.payload-1275)\n}\n\nif(msg.payload < 511 ){\n \nmsg.out = 0\n}\n\nif(msg.payload >= 765 && msg.payload <= 1275){\n \nmsg.out = 255\n \n}\nreturn msg;", "outputs": 1, "noerr": 0, "initialize": "", "finalize": "", "x": 600, "y": 320, "wires": [ [ "2f6c8bba.750a44" ] ] }, { "id": "60867af.c83e284", "type": "change", "z": "2faf5f0b.6de9e", "name": "", "rules": [ { "t": "move", "p": "out", "pt": "msg", "to": "payload", "tot": "msg" } ], "action": "", "property": "", "from": "", "to": "", "reg": false, "x": 750, "y": 240, "wires": [ [ "7eae1821.3959c8" ] ] }, { "id": "fa96e0aa.7c", "type": "change", "z": "2faf5f0b.6de9e", "name": "", "rules": [ { "t": "move", "p": "out", "pt": "msg", "to": "payload", "tot": "msg" } ], "action": "", "property": "", "from": "", "to": "", "reg": false, "x": 750, "y": 280, "wires": [ [ "71029cdb.259004" ] ] }, { "id": "2f6c8bba.750a44", "type": "change", "z": "2faf5f0b.6de9e", "name": "", "rules": [ { "t": "move", "p": "out", "pt": "msg", "to": "payload", "tot": "msg" } ], "action": "", "property": "", "from": "", "to": "", "reg": false, "x": 750, "y": 320, "wires": [ [ "270602f.2d91d7e" ] ] }, { "id": "7eae1821.3959c8", "type": "ioBroker out", "z": "2faf5f0b.6de9e", "name": "Herrenplätze Rot", "topic": "hue.0.Herrenplätze.r", "ack": "false", "autoCreate": "false", "stateName": "", "role": "", "payloadType": "", "readonly": "", "stateUnit": "", "stateMin": "", "stateMax": "", "x": 940, "y": 240, "wires": [] }, { "id": "71029cdb.259004", "type": "ioBroker out", "z": "2faf5f0b.6de9e", "name": "Herrenplätze Grün", "topic": "hue.0.Herrenplätze.g", "ack": "false", "autoCreate": "false", "stateName": "", "role": "", "payloadType": "", "readonly": "", "stateUnit": "", "stateMin": "", "stateMax": "", "x": 940, "y": 280, "wires": [] }, { "id": "270602f.2d91d7e", "type": "ioBroker out", "z": "2faf5f0b.6de9e", "name": "Herrenplätze Blau", "topic": "hue.0.Herrenplätze.b", "ack": "false", "autoCreate": "false", "stateName": "", "role": "", "payloadType": "", "readonly": "", "stateUnit": "", "stateMin": "", "stateMax": "", "x": 940, "y": 320, "wires": [] } ]
Da hier nur JS verwendet wird kann das auch im JS Adapter passieren.
-
@a200
Tolle Lösung! Wärest du bereit den Code davon zu teilen? -
@hipohop Klar.
Die verwendeten Datenpunkte sind:
esphome.0.E8DB84E3AF1D.Light.801952849.brightness - Hier wird die Helligkeit (0-255) gesetzt.
esphome.0.E8DB84E3AF1D.Light.801952849.state - Hier wird der Zustand abgefragt: true/false (ist an/ist aus)
esphome.0.E8DB84E3AF1D.Switch.647169867.state - Hier schalte ich die LEDs: true/false (ein/aus)
esphome.0.E8DB84E3AF1D.Light.801952849.colorHEX - Hier setze ich die Farbe (RGB)Diese Datenpunkte kommen öfter vor und müssen überall durch deine DP ersetzt werden. Am besten im Editor mit cut/paste.
Wegen der Besonderheit von ESPhome muss ich den neuen Zustand in einem anderen DP setzen, als ich den auslese. Normalerweise dürften das aber die gleichen DP sein.
Melde dich, wenn du Fragen hast.
View:
-
@a200
Danke Dir sehr. Werde ich am Wochenende ausprobieren -
@hipohop Hier noch eine Alternative, die auf @CrunkFX basiert.
- Material Design Widgets-Adapter installieren.
- Datenpunkt anlegen:
3. Widget importieren.
4. Javascript erstellen, Zeile 5 anpassen und aktivieren:
Änderungen:
04.02.2022 19:11 Javascript: Korrektur wg. Typecasting.
04.02.2022 20:40 Widget: Grafik gegen CSS ausgetauscht.Läuft bei mir sehr gut.
-
@a200
Danke! Schau ich mir auch an -
ihr habt ja jetzt die lösung
was ich auch noch gut finde, ist die benutzung irgendeines bildes und das dann auslesen
das bild sieht in echt besser aus, liegt am aufnahme tool
-
@a200
Funktioniert auf Anhieb. Danke nochmal