Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Cloud Dienste
    4. [Frage/Anforderung] Farbige Lampen mit RGB Datenpunkten (ohne HUE) in Alexa

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [Frage/Anforderung] Farbige Lampen mit RGB Datenpunkten (ohne HUE) in Alexa

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

      Also da am Wochenende der Shelly Adapter mit einem RGBW Datenpunkt ausgestatt wurde, welcher die Farbe in Format #RRGGBBWW ausgiebt, funktioniert die Farbe. 🙂

      Nun habe ich jedoch noch die Frage nach dem "Switch" Datenpunkt im IOT Adapter? Nutzt der IOT Adapter diesen überhaupt wenn er einen dimmer Wert hat? Wenn ich sage "Schalte das Licht an", stellt er anscheinend nur den Dimmwert hoch. Ich würde jedoch gerne haben, dass er den Switch Datenpunkt schaltet. Kann man das irgendwie realisieren?
      Der Grund ist: Da bei den Shelly RGBWs der White Wert vom Helligkeitswert entkoppelt ist und separat gesteuert wird, kann ich somit die Beleuchtung nicht per Sprache ausschalten, wenn Weiß an ist.

      madjack84 1 Reply Last reply Reply Quote 0
      • madjack84
        madjack84 @siggi85 last edited by madjack84

        @siggi85 Hey hab heute das gleiche mit dem RGBW2 Adapter per Blockly angesteuert.
        c441a9a7-34fb-4a2a-91bf-3f176e42e2f0-image.png

        Folgendes Dinge musst du tun:

        1. Variable "led_strip_mgr" mit Rolle level.color.rgb anlegen
        2. im Cloud Adapter ein Kommando anlegen
        3. Blockly: Trigger auf diese Variable und dann die Werte lesen. (On/Off separat abfangen, der Rest steuert das Licht.
        4. die JS Funktion ist nur
        return parseInt(i, 16);
        

        mehr nicht.
        Dann das JSON Ergebnis in set schreiben (bei mir MQTT)

        siggi85 1 Reply Last reply Reply Quote 1
        • siggi85
          siggi85 @madjack84 last edited by

          @madjack84 Wow clever gelöst! Und danke, dass du mir geantwortet hast obwohl die Anfrage schon so lange her ist. Werde das demnächst mal so umsetzen! ☺

          1 Reply Last reply Reply Quote 1
          • E
            e-s @Asgothian last edited by e-s

            @Asgothian sagte in [Frage/Anforderung] Farbige Lampen mit RGB Datenpunkten (ohne HUE) in Alexa:

            @siggi85
            Ich nutz das hier:
            https://github.com/Qix-/color-convert

            Wichtig dabei: Hue muss 0-360 sein, sat 0-100 und val auch 0-100. Raus kommt RGB als 0-255 jeweils

            Sorry für meine Nachfrage, wie genau kann ich das benutzen um so umzurechnen?

            Asgothian 1 Reply Last reply Reply Quote 0
            • Asgothian
              Asgothian Developer @e-s last edited by

              @e-s
              du musst es als erstes im Javascript Adapter als externe Bibliothek hinzufügen.

              In der Folge kannst du dann per "require" im Skript einbinden und Funktionen daraus aufrufen.

              colorconv = require("color-convert")
              
              rgb_color = colorconv.hsv.rgb(hue, sat, value)
              

              Der Rest sollte sich aus der Doku der Bibliothek auf Github ergeben.

              A.

              E 1 Reply Last reply Reply Quote 0
              • E
                e-s @Asgothian last edited by

                @Asgothian
                Ich verstehe leider nur Bahnhof, bzw kein js. Mit Blockly komme ich langsam klar, aber mehr auch nicht.
                Das mit der Bibliothek habe ich verstanden und auch eingefügt.
                Aber wie ich jetzt ein hue übergebe und rgb zurück bekomme, ist mir noch unklar.

                Wie gesagt, verstehe derzeit nur Ansatzweise Blockly, hab da jetzt Funktion, js mit Ergebnis hinzugefügt und dort dann den Codeschnipsel eingefügt, richtig?

                Asgothian 1 Reply Last reply Reply Quote 0
                • Asgothian
                  Asgothian Developer @e-s last edited by

                  @e-s nein.

                  Wie / ob es mit blockly geht weiß ich nicht. Ich nutze js direkt.

                  A.

                  E 1 Reply Last reply Reply Quote 0
                  • E
                    e-s @Asgothian last edited by

                    @Asgothian
                    Könntest du mir bitte kurz den ganzen Code zeigen mit dem du hue übergibst und rgb zurück bekommst, Dann komme ich schon klar.

                    Asgothian 1 Reply Last reply Reply Quote 0
                    • Asgothian
                      Asgothian Developer @e-s last edited by Asgothian

                      @e-s

                      var cv = require('color-convert');
                      var timeout = null;
                      
                      on({id:['javascript.0.hue','javascript.0.sat','javascript.0.brightness'], change:"ne"}, function() { if (!timeout) setTimeout(ConvertHueToRgb, 200) });
                      
                      function getValue(id)
                      {
                        var state = getState(id)
                        if (state.val) return state.val
                        return 0
                      }
                      
                      function rgbToHex(rgb) { 
                        var hex = Number(rgb).toString(16);
                        if (hex.length < 2) {
                             hex = "0" + hex;
                        }
                        return hex;
                      };
                      
                      function fullColorHex(r,g,b) {   
                        var red = rgbToHex(r);
                        var green = rgbToHex(g);
                        var blue = rgbToHex(b);
                        return red+green+blue;
                      };
                      
                      function ConvertHueToRgb()
                      {
                        timeout = null;
                        var hue = getValue('javascript.0.hue')
                        var sat = getValue('javascript.0.saturation')
                        var val = getValue('javascript.0.brightness')
                        var rgb = cv.hsv.rgb(hue, sat, val)
                        var rgbString = fullColorHex(rgb[0],rgb[1],rgb[2])
                        // hier kannst du entweder den rgbString oder direkt die r, g, b werte aus dem Array rgb nutzen.
                      }
                      

                      So nutze ich das - extrahiert aus einem deutlich grösseren Script, deswegen ggf. mit einem oder zwei Schreibfehlern. Zusätzlich musst du noch die color-convert Bibliothek in den Einstellungen des JS adapters angeben, damit sie verfügbar ist.

                      Einfach nur aus dem "hue" einen RGB wert machen geht nicht. "sat" und "brightness" müssen IMMER mit dazu.

                      Die Datenpunkte javascript.0.xxx musst du natürlich auf die Ummappen die du mit Alexa nutzen willst. Auch das endgültige Format des RGB (direkt string, mit '#" voran, etc) musst du noch festlegen, das hängt davon ab was deine Lampe haben will.

                      Viel Glück damit.

                      A.

                      AxelF1977 1 Reply Last reply Reply Quote 0
                      • AxelF1977
                        AxelF1977 @Asgothian last edited by AxelF1977

                        @Asgothian sagte in [Frage/Anforderung] Farbige Lampen mit RGB Datenpunkten (ohne HUE) in Alexa:

                        @e-s

                        So nutze ich das - extrahiert aus einem deutlich grösseren Script, deswegen ggf. mit einem oder zwei Schreibfehlern. Zusätzlich musst du noch die color-convert Bibliothek in den Einstellungen des JS adapters angeben, damit sie verfügbar ist.

                        Einfach nur aus dem "hue" einen RGB wert machen geht nicht. "sat" und "brightness" müssen IMMER mit dazu.

                        Die Datenpunkte javascript.0.xxx musst du natürlich auf die Ummappen die du mit Alexa nutzen willst. Auch das endgültige Format des RGB (direkt string, mit '#" voran, etc) musst du noch festlegen, das hängt davon ab was deine Lampe haben will.

                        Viel Glück damit.

                        A.

                        @Asgothian ich nehme das Thema hier nochmal auf, da ich eine ähnliche Problematik habe. Ich muss von ein paar Birnen (OSRAM in HUE eingebunden) die R G B werte einzeln extrahieren. Ich hatte gehofft der Codeschnippsel oben von Dir würde dies tun. Leider tut er nichts, ich denke aber lkiegt eher an meine Unkenntnis. Könntest Du mir da kurz helfen?

                        Wie folgt habe ich das Script eingebunden

                        var cv = require('color-convert');
                        var timeout = null;
                         
                        on({id:['0_userdata.0.vis.hue.hue','0_userdata.0.vis.hue.saturation','0_userdata.0.vis.hue.brightness'], change:"ne"}, function() { if (!timeout) setTimeout(ConvertHueToRgb, 200) });
                         
                        function getValue(id)
                        {
                          var state = getState(id)
                          if (state.val) return state.val
                          return 0
                        }
                         
                        function rgbToHex(rgb) { 
                          var hex = Number(rgb).toString(16);
                          if (hex.length < 2) {
                               hex = "0" + hex;
                          }
                          return hex;
                        };
                         
                        function fullColorHex(r,g,b) {   
                          var red = rgbToHex(r);
                          var green = rgbToHex(g);
                          var blue = rgbToHex(b);
                          return red+green+blue;
                        };
                         
                        function ConvertHueToRgb()
                        {
                          timeout = null;
                          var hue = getValue('hue-extended.0.groups.wohnzimmer_licht_leselampe.action.hue')
                          var sat = getValue('hue-extended.0.groups.wohnzimmer_licht_leselampe.action.saturation')
                          var val = getValue('hue-extended.0.groups.wohnzimmer_licht_leselampe.action.brightness')
                          var rgb = cv.hsv.rgb(hue, sat, val)
                          var rgbString = fullColorHex(rgb[0],rgb[1],rgb[2])
                          // hier kannst du entweder den rgbString oder direkt die r, g, b werte aus dem Array rgb nutzen.
                        }
                        

                        color-convert ist im Javascript Adapter eingebunden

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

                        Support us

                        ioBroker
                        Community Adapters
                        Donate
                        FAQ Cloud / IOT
                        HowTo: Node.js-Update
                        HowTo: Backup/Restore
                        Downloads
                        BLOG

                        875
                        Online

                        31.9k
                        Users

                        80.2k
                        Topics

                        1.3m
                        Posts

                        alexa cloud iot pro
                        6
                        19
                        3425
                        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