Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Colorpicker für dicke Finger

    NEWS

    • Neues Video über Aliase, virtuelle Geräte und Kategorien

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    Colorpicker für dicke Finger

    This topic has been deleted. Only users with topic management privileges can see it.
    • a200
      a200 last edited by

      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.

      1 Reply Last reply Reply Quote 0
      • S
        Supermicha last edited by

        ich weiß nicht, ob dir das hilft...

        ich habe mit einen selbergebaut, es ist kein "vollwertiger" Colorpicker, er enthält nur die Grundfarben...
        21b3fea8-3d4e-48de-987a-741f61c59aa3-grafik.png

        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

        a200 1 Reply Last reply Reply Quote 1
        • a200
          a200 @Supermicha last edited by

          @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.

          liv-in-sky 1 Reply Last reply Reply Quote 0
          • S
            Supermicha last edited by

            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. 😊

            1 Reply Last reply Reply Quote 0
            • liv-in-sky
              liv-in-sky @a200 last edited by

              @a200

              kannst du damit was anfangen ?

              Image 5.png

              in de vis:

              Image 7.png

              a200 1 Reply Last reply Reply Quote 3
              • S
                Supermicha last edited by

                das wusste ich auch noch nicht...

                1 Reply Last reply Reply Quote 0
                • a200
                  a200 @liv-in-sky last edited by

                  @liv-in-sky Stimmt, das ist eine gute Idee. Auch wenn mir nur der Farbenring vollkommen reichen würde. Danke!

                  1 Reply Last reply Reply Quote 0
                  • S
                    Supermicha last edited by

                    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...

                    a200 1 Reply Last reply Reply Quote 0
                    • a200
                      a200 @Supermicha last edited by a200

                      @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.

                      004.png LED ist an

                      005.png LED ist aus

                      Wird der Schalter angeklickt erscheint ein Dialog:

                      001.png Farbring: Farbauswahl
                      Innerer Ring: Helligkeit. Dabei wird die jeweils aktuelle Farbe verwendet.
                      Kleiner Kreis: Ein/Aus Knopf

                      Screenshot 2022-02-02 133247.png Gesamteindruck

                      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.

                      H 1 Reply Last reply Reply Quote 0
                      • CrunkFX
                        CrunkFX Forum Testing last edited by CrunkFX

                        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:
                        33b5c00b-8716-4005-b5a9-beba28fa3b09-image.png
                        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.

                        1 Reply Last reply Reply Quote 0
                        • H
                          hipohop @a200 last edited by

                          @a200
                          Tolle Lösung! Wärest du bereit den Code davon zu teilen?

                          a200 1 Reply Last reply Reply Quote 0
                          • a200
                            a200 @hipohop last edited by a200

                            @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:

                            {
                             "settings": {
                               "style": {
                                 "background_class": "hq-background-carbon-fibre",
                                 "background": ""
                               },
                               "theme": "redmond",
                               "sizex": "",
                               "sizey": "",
                               "gridSize": "",
                               "snapType": null,
                               "useBackground": true
                             },
                             "widgets": {
                               "e00001": {
                                 "tpl": "tplHqCircle",
                                 "data": {
                                   "g_fixed": false,
                                   "g_visibility": false,
                                   "g_css_font_text": false,
                                   "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",
                                   "oid": "esphome.0.E8DB84E3AF1D.Light.801952849.brightness",
                                   "min": "10",
                                   "max": "250",
                                   "digits": "0",
                                   "step": "10",
                                   "is_comma": false,
                                   "displayPrevious": "true",
                                   "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,
                                   "descriptionLeft": "brightness of H801 Light",
                                   "angleOffset": "250",
                                   "angleArc": "220",
                                   "color": "{esphome.0.E8DB84E3AF1D.Light.801952849.colorHEX}"
                                 },
                                 "style": {
                                   "left": "221px",
                                   "top": "190px",
                                   "width": "400px",
                                   "height": "400px",
                                   "z-index": "30"
                                 },
                                 "widgetSet": "hqwidgets"
                               },
                               "e00002": {
                                 "tpl": "tplRGBFarbtastic",
                                 "data": {
                                   "g_fixed": false,
                                   "g_visibility": false,
                                   "g_css_font_text": false,
                                   "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",
                                   "factor": "1",
                                   "decimal": "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,
                                   "g_rgb": false,
                                   "rgb-oid": "esphome.0.E8DB84E3AF1D.Light.801952849.colorHEX",
                                   "g_hue": false
                                 },
                                 "style": {
                                   "left": "330px",
                                   "top": "330px",
                                   "transform": "scale(4)",
                                   "width": "200px",
                                   "height": "200px",
                                   "z-index": "10"
                                 },
                                 "widgetSet": "colorpicker"
                               },
                               "e00003": {
                                 "tpl": "tplIconState",
                                 "data": {
                                   "oid": "esphome.0.E8DB84E3AF1D.Switch.647169867.state",
                                   "g_fixed": true,
                                   "g_visibility": false,
                                   "g_css_font_text": true,
                                   "g_css_background": true,
                                   "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",
                                   "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,
                                   "text": "{val:esphome.0.E8DB84E3AF1D.Light.801952849.state; val==\"true\" ? \"Aus\": val==\"false\" ? \"Ein\": \"unbekannt\"}",
                                   "value": "",
                                   "src": "",
                                   "imageHeight": "",
                                   "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,
                                   "views": [
                                     "0-EG",
                                     "0-HW",
                                     "2-Dosen"
                                   ]
                                 },
                                 "style": {
                                   "left": "321px",
                                   "top": "486px",
                                   "width": "200px",
                                   "height": "200px",
                                   "background": "transparent",
                                   "border-radius": "100px",
                                   "border-width": "2px",
                                   "border-style": "solid",
                                   "border-color": "{val:esphome.0.E8DB84E3AF1D.Light.801952849.state; val==\"true\" ? \"#14ff1f\": val==\"false\" ? \"#777\": \"yellowgreen\"}",
                                   "padding-bottom": "",
                                   "z-index": "40",
                                   "box-shadow": "0 0 20px grey",
                                   "background-color": "#222",
                                   "color": "#ffffff"
                                 },
                                 "widgetSet": "jqui"
                               },
                               "e00004": {
                                 "tpl": "tplHtml",
                                 "data": {
                                   "g_fixed": false,
                                   "g_visibility": false,
                                   "g_css_font_text": false,
                                   "g_css_background": true,
                                   "g_css_shadow_padding": false,
                                   "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
                                 },
                                 "style": {
                                   "left": "124px",
                                   "top": "126px",
                                   "z-index": "20",
                                   "background-color": "#222",
                                   "width": "594px",
                                   "height": "594px",
                                   "border-radius": "296px"
                                 },
                                 "widgetSet": "basic"
                               }
                             },
                             "name": "LED-RGB",
                             "filterList": []
                            }
                            

                            H 2 Replies Last reply Reply Quote 1
                            • H
                              hipohop @a200 last edited by

                              @a200
                              Danke Dir sehr. Werde ich am Wochenende ausprobieren

                              a200 1 Reply Last reply Reply Quote 0
                              • a200
                                a200 @hipohop last edited by a200

                                @hipohop Hier noch eine Alternative, die auf @CrunkFX basiert.

                                1. Material Design Widgets-Adapter installieren.
                                2. Datenpunkt anlegen:

                                {
                                 "common": {
                                   "name": "Position",
                                   "desc": "RGB-Slider Position (1-1530)",
                                   "role": "state",
                                   "type": "string",
                                   "read": true,
                                   "write": true,
                                   "def": ""
                                 },
                                 "type": "state",
                                 "_id": "0_userdata.0.Vis_Slider.Position",
                                 "acl": {
                                   "object": 1636,
                                   "state": 1636,
                                   "owner": "system.user.admin",
                                   "ownerGroup": "system.group.administrator"
                                 },
                                 "from": "system.adapter.admin.0",
                                 "user": "system.user.admin",
                                 "ts": 1643995809017
                                }
                                


                                3. Widget importieren.

                                [{"tpl":"tplVis-materialdesign-Vuetify-Slider","data":{"oid":"0_userdata.0.Vis_Slider.Position","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":true,"g_css_shadow_padding":false,"g_css_border":true,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","orientation":"horizontal","knobSize":"knobSmall","step":"5","vibrateOnMobilDevices":"50","showTicks":"no","tickTextColor":"","tickFontFamily":"","tickFontSize":"","tickColorBefore":"","tickColorAfter":"","colorBeforeThumb":"","colorThumb":"RGBA(0,0,0,0)","colorAfterThumb":"","showThumbLabel":"no","thumbBackgroundColor":"","thumbFontColor":"","thumbFontSize":"","thumbFontFamily":"","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,"generateHtmlControl":"true","min":"1","max":"1530","g_label":true,"prepandTextColor":"","prepandTextFontSize":"","prepandTextFontFamily":"","showValueLabel":false,"valueLabelStyle":"sliderValue","valueFontFamily":"","valueFontSize":"","valueLabelColor":"","valueLabelWidth":"50","thumbSize":""},"style":{"left":"513px","top":"541px","background-color":"","background-repeat":"","background":"linear-gradient(90deg, red,yellow,#16ff00,cyan,blue,#ff00ed,red)","background-attachment":"","z-index":"14","width":"1206px","height":"120px","border-radius":"10px"},"widgetSet":"materialdesign"}]
                                


                                4. Javascript erstellen, Zeile 5 anpassen und aktivieren:

                                // Liest den dp (slider in VIS) aus, wandelt den Wert von (0-1530) nach RGB und speichert in ESP-LED-Stripe
                                //
                                
                                // Hier den Datenpunkt angeben aus dem die Lampe/Strips/usw sich die Farbe holt. Format #RRGGBB
                                var dpout = "esphome.0.E8DB84E3AF1D.Light.801952849.colorHEX";
                                //
                                
                                
                                var dp = "0_userdata.0.Vis_Slider.Position";
                                var c = 0;
                                var red, green, blue;
                                var debug = false;
                                
                                
                                on({id: dp, change: 'ne'}, function (obj) {
                                   c = obj.state.val;
                                
                                   // Rot
                                   if(c >= 256 && c <= 510){
                                       red = 255 - (c-255);
                                   }
                                   if(c >= 1021 && c <= 1275){
                                   	red = (c-1020)
                                   }
                                   if(c < 256 || c > 1275){
                                       red = 255
                                   }
                                
                                   // Blau
                                   if(c >= 511 && c < 765){
                                       blue = (c-510)
                                   }
                                   if(c > 1275 ){
                                       blue = 255- (c-1275)
                                   }
                                   if(c < 511 ){
                                       blue = 0
                                   }
                                   if(c >= 765 && c <= 1275){
                                       blue = 255
                                   }
                                
                                   // Gruen
                                   if(c < 256){
                                       green = c
                                   }
                                   if(c >= 256 && c < 766){
                                       green = 255
                                   }
                                   if(c >= 1020 ){
                                       green = 0
                                   }
                                   if(c >= 766 && c < 1020){
                                       green = 255 - (c-765)
                                   }
                                
                                   setState(dpout, "#"+ parseInt(red).toString(16).padEnd(2, '0') + "" + parseInt(green).toString(16).padEnd(2, '0') + "" + parseInt(blue).toString(16).padEnd(2, '0'));
                                   if(debug) log("Wert: " + c + " RGB=#" + parseInt(red).toString(16).padEnd(2, '0') + " " +parseInt(green).toString(16).padEnd(2, '0')+" "+parseInt(blue).toString(16).padEnd(2, '0'))
                                });
                                


                                Ä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.

                                H 1 Reply Last reply Reply Quote 1
                                • H
                                  hipohop @a200 last edited by

                                  @a200
                                  Danke! Schau ich mir auch an

                                  1 Reply Last reply Reply Quote 0
                                  • liv-in-sky
                                    liv-in-sky last edited by

                                    ihr habt ja jetzt die lösung

                                    was ich auch noch gut finde, ist die benutzung irgendeines bildes und das dann auslesen

                                    AApossis (185).gif

                                    das bild sieht in echt besser aus, liegt am aufnahme tool

                                    1 Reply Last reply Reply Quote 2
                                    • H
                                      hipohop @a200 last edited by

                                      @a200
                                      Funktioniert auf Anhieb. Danke nochmal

                                      1 Reply Last reply Reply Quote 0
                                      • First post
                                        Last post

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      847
                                      Online

                                      32.0k
                                      Users

                                      80.5k
                                      Topics

                                      1.3m
                                      Posts

                                      vis
                                      5
                                      17
                                      1094
                                      Loading More Posts
                                      • Oldest to Newest
                                      • Newest to Oldest
                                      • Most Votes
                                      Reply
                                      • Reply as topic
                                      Log in to reply
                                      Community
                                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                      The ioBroker Community 2014-2023
                                      logo