Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Praktische Anwendungen (Showcase)
    4. [How-to] Hue Dimmer-Schalter: alle Tastendrücke einfach auswerten

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [How-to] Hue Dimmer-Schalter: alle Tastendrücke einfach auswerten

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

      Sigi, Du bist hier beim Dimmer Schalter,Du suchst den Motion Sensor 😄 😄 😄

      1 Reply Last reply Reply Quote 0
      • sigi234
        sigi234 Forum Testing Most Active last edited by

        upps

        1 Reply Last reply Reply Quote 0
        • Mic
          Mic Developer last edited by

          @Andy_68:

          Vielleicht kannst Du ja sogar den Flow mal exportieren 😉 `

          @sigi234:

          Dafür wäre ich auch dankbar…..... 🙂 `

          Hi zusammen,

          gerne, also diesen Flow habe ich exportiert:
          6940_zwischenablage01.png

          Hier der Export:

          ! ````
          [
          {
          "id": "f4bad278.cc832",
          "type": "hue-switch",
          "z": "cb8e827e.1b7c7",
          "name": "Schalter-Wohnlicht",
          "bridge": "ec9ad76d.8ede48",
          "sensorid": "2",
          "x": 110,
          "y": 80,
          "wires": [
          [
          "c05b3eb1.b0bcb",
          "d101536.0344db",
          "31776f58.e3335"
          ]
          ]
          },
          {
          "id": "1b6e5a28.db6ae6",
          "type": "ioBroker out",
          "z": "cb8e827e.1b7c7",
          "name": "Set Button Name",
          "topic": "javascript.0.mic.hue.dimmer-switch.wohnzimmer.button",
          "ack": "false",
          "autoCreate": "false",
          "x": 690,
          "y": 80,
          "wires": []
          },
          {
          "id": "c05b3eb1.b0bcb",
          "type": "function",
          "z": "cb8e827e.1b7c7",
          "name": "Get Button Name",
          "func": "msg.payload = msg.payload.name;\nreturn msg;",
          "outputs": 1,
          "noerr": 0,
          "x": 450,
          "y": 80,
          "wires": [
          [
          "1b6e5a28.db6ae6"
          ]
          ]
          },
          {
          "id": "d101536.0344db",
          "type": "function",
          "z": "cb8e827e.1b7c7",
          "name": "Get Button Action",
          "func": "msg.payload = msg.payload.action;\nreturn msg;",
          "outputs": 1,
          "noerr": 0,
          "x": 450,
          "y": 140,
          "wires": [
          [
          "8bdc8c84.03e85"
          ]
          ]
          },
          {
          "id": "8bdc8c84.03e85",
          "type": "ioBroker out",
          "z": "cb8e827e.1b7c7",
          "name": "Set Button Action",
          "topic": "javascript.0.mic.hue.dimmer-switch.wohnzimmer.action",
          "ack": "false",
          "autoCreate": "false",
          "x": 690,
          "y": 140,
          "wires": []
          },
          {
          "id": "31776f58.e3335",
          "type": "function",
          "z": "cb8e827e.1b7c7",
          "name": "Get Button Updated on",
          "func": "msg.payload = msg.payload.updated;\nreturn msg;",
          "outputs": 1,
          "noerr": 0,
          "x": 460,
          "y": 200,
          "wires": [
          [
          "f3f19322.ce44d"
          ]
          ]
          },
          {
          "id": "f3f19322.ce44d",
          "type": "ioBroker out",
          "z": "cb8e827e.1b7c7",
          "name": "Set Button Updated On",
          "topic": "javascript.0.mic.hue.dimmer-switch.wohnzimmer.updated",
          "ack": "false",
          "autoCreate": "false",
          "x": 710,
          "y": 200,
          "wires": []
          },
          {
          "id": "ec9ad76d.8ede48",
          "type": "hue-bridge",
          "z": "",
          "name": "Philips hue",
          "bridge": "10.10.0.101",
          "key": "KEY_HIER_EINTRAGEN",
          "interval": "3000"
          }
          ]

          
          Und hier noch das JavaScript von mir, welches die Datenpunkte erzeugt, die dann entsprechend ausgewertet werden können für jeden der 4 Knöpfe und kurz oder lange drückend.
           ![6940_zwischenablage02.png](/assets/uploads/files/6940_zwischenablage02.png) 
          
          >! ````
          /****************************************************************************************
           * Setup
           ****************************************************************************************/
          const STATE_PATH = 'javascript.'+ instance + '.' + 'mic.hue.';
          >! /****************************************************************************************
           * Create States
           ****************************************************************************************/
          // Hue Schalter Wohnzimmer - für node.red!
          MG_createState (STATE_PATH + 'dimmer-switch.wohnzimmer.button', 'Hue: Welcher Button wurde gedrückt', 'string', 'hue-button', '');
          MG_createState (STATE_PATH + 'dimmer-switch.wohnzimmer.action', 'Hue: Wie wurde der Button gedrückt', 'string', 'hue-button', '');
          MG_createState (STATE_PATH + 'dimmer-switch.wohnzimmer.updated', 'Hue: Wann wurde der Button gedrückt', 'string', 'hue-button', '');
          >! /****************************************************************************************
           * node-red: Hue Dimmer Switch - Wohnzimmer
           ****************************************************************************************/
          on({id: STATE_PATH + 'dimmer-switch.wohnzimmer.updated', change: "any"}, function (obj) {
          >!     // (pressed, holded, short released, long released)
              var hueBtnAction = getState(STATE_PATH + 'dimmer-switch.wohnzimmer.action').val;
          >!     // (On, Dim Up, Dim Down, Off)
              switch (getState(STATE_PATH + 'dimmer-switch.wohnzimmer.button').val) {
                  case "On":
                      switch (hueBtnAction) {
                          case "short released":
                              // Hier Code für Long Released
                              break;
                          case "long released":
                              // Hier Code für Long Released
                              break;
                      }
                      break;
                  case "Dim Up":
                      switch (hueBtnAction) {
                          case "short released":
                              // Hier Code für Short Released
                              break;
                          case "long released":
                              // Hier Code für Long Released
                              break;
                      }
                      break;
                  case "Dim Down":
                      switch (hueBtnAction) {
                          case "short released":
                              // Hier Code für Short Released
                              break;
                          case "long released":
                              // Hier Code für Long Released
                              break;
                      }
                      break;
                  case "Off":
                      switch (hueBtnAction) {
                          case "short released":
                              // Hier Code für Short Released
                              break;
                          case "long released":
                              // Hier Code für Short Released
                              break;
                      }
                      break;
              }
          });
          >! /**
           * Create States - General
           * @param {string} stId      ID
           * @param {string} stName    Name, Description
           * @param {mixed}  stType     Datatype: string, boolean, etc.
           * @param {string} stRole    Role: button, etc.
           * @param {mixed}  stDef      Default value
           */
          function MG_createState(stId, stName, stType, stRole, stDef) {
              createState(stId, {
                  'name': stName,
                  'desc': stName,
                  'type': stType,
                  'read': true,
                  'write': true,
                  'role': stRole,
                  'def': stDef,
              });
          }
          >! ````
          
          Im Script sind Euren Freiheiten im Prinzip keine Grenzen gesetzt :)
          
          Also für Dimmen dann entsprechend den entsprechenden Datenpunkt auslesen und z.B. um -10 heruntersetzen…..
          1 Reply Last reply Reply Quote 0
          • haselchen
            haselchen Most Active last edited by

            Erstmal vielen Dank Mic für die Bereitstellung. Ist ja auch nicht selbstverständlich.

            Ich habe bei lastupdate das Problem, dass er anscheinend zeitlich in ner anderen Zone ist 🙂

            3723_zeit.png

            Zeitzonen sind alle richtig eingestellt.

            In der Hue App ist auch alles korrekt.

            Wo kommen die +0200 Stunden her? Oder besser, wie bekomme ich sie weg.

            (Im HUE Adapter sieht es genauso aus, GMT +0200)

            1 Reply Last reply Reply Quote 0
            • Mic
              Mic Developer last edited by

              @haselchen:

              Wo kommen die +0200 Stunden her? `

              Siehe z.B. hier: https://greenwichmeantime.com/time-zone/gmt-plus-2/

              Wenn Dich das stört, dann kannst Du das ja im auswertenden Script entsprechend kalkulieren/korrigieren.

              1 Reply Last reply Reply Quote 0
              • haselchen
                haselchen Most Active last edited by

                Wenn ich das könnte, würde ich es ja machen 😉

                1 Reply Last reply Reply Quote 0
                • Mic
                  Mic Developer last edited by

                  Das kann man lernen 🙂 Hier z.B.: https://javascript.info/date

                  1 Reply Last reply Reply Quote 0
                  • haselchen
                    haselchen Most Active last edited by

                    @Mic

                    Muss das Thema leider nochmal hochholen.

                    Ich habe die Objekte/Datenpunkte manuell angelegt, weil mein Javascript Adapter irgendwie ne Menge Ressourcen frisst.

                    Die beiden ersten Punkte werden live befüllt, nur beim updated Datenpunkt kommt nichts.

                    Woran mag das liegen.
                    3723_unbenannt1.png

                    function Node sieht so aus:

                    3723_unbenannt2.png

                    Wie kriege ich den Zeitstempel in das updatet Feld? (ohne Javascript)

                    1 Reply Last reply Reply Quote 0
                    • haselchen
                      haselchen Most Active last edited by

                      Selbst gelöst :lol: :lol:

                      Hab Dein Script genommen…Datenpunkte erstellen lassen...Script aus.

                      Datenpunkt angepasst, wie ich sie hatte.

                      Und das Datum im Werte Feld vernünftig per Blockly konvertiert.

                      THX Mic 😉

                      1 Reply Last reply Reply Quote 0
                      • N
                        nousefor82 last edited by

                        Lieber Mic,

                        es funktioniert hervorragned!

                        Bin total begeistert!!

                        Vielen Dank für deine Mühen!

                        Gruß

                        Jörg

                        1 Reply Last reply Reply Quote 0
                        • 123brokerei
                          123brokerei last edited by

                          Hallo,

                          sehe ich es richtig, dass man mit dieser Lösung immer nur zu den polling-Intervallen eine Rückmeldung zu den Sensordaten bekommt? Falls ja, was wäre ein "noch" sinnvoller möglichst kleiner Wert?

                          Grüße

                          1 Reply Last reply Reply Quote 0
                          • haselchen
                            haselchen Most Active last edited by

                            Die Rückmeldung kommt in Millisekunden, wie schnell willst Du es noch haben?

                            1 Reply Last reply Reply Quote 0
                            • 123brokerei
                              123brokerei last edited by

                              Hi,

                              bei mir ist das leider nicht der Fall. Je nach dem was ich beim polling-Intervall eingestellt habe kann es eben so lange dauern (Standardwert z.B. 3000ms => siehe Screenshot) Wenn ich unter 1000ms gehe bringt es gefühlt nichts mehr, da dann wohl die Abfrageperformance in die Knie geht und selbst eine Sekunde ist als Reaktionszeit schon grenzwertig lang für mich. Daher wäre meine nächste Frage, was ihr in der Polling Intervall stehen habt, da eine Wertangabe wohl zwingend nötig ist.

                              Grüße Michael

                              0a3cb804-54e0-45f2-ac91-7cff21152834-grafik.png

                              1 Reply Last reply Reply Quote 0
                              • E
                                extbingh last edited by Jey Cee

                                Guten Morgen,

                                ich wollte gerade folgendes nachgehen: https://forum.iobroker.net/topic/10476/alexa-anbindung-ohne-cloud-und-skill

                                Zusammengefasst, ich will 3 Tasmota Birnen über ein Philips Hue Dimmschalter steuern in Node-Red oder auch sonst wo.

                                Ich habe das schon bereits mit den Sonoff sowie Philips Hue Extended Adapter Datenpunkten/objects geschafft, jedoch gibt es dort eine Verzögerung von 6-7 Sekunden. Die Datenpunkte/objects habe ich vom Philips Hue Extended Adapter für den Dimmschalter.

                                Ich habe die 3 Datenpunkte wie folgt erstellt:

                                3x.jpg

                                Node-Red sowie Philips Hue Magic installiert.

                                Schritt 4 verstehe ich nicht, bzw. wie man so ein "Music/Cinema" Tab erstellt und wofür das gut sein soll bzw. man das machen muss? Also das hier:

                                6940_clipboard02.jpg

                                Schritt 5 (Philips Hue Bridge hinzugefügt, Dimmschalter etc.) und folgende habe ich alle.

                                Sieht nun so aus:

                                war.jpg

                                Jetzt habe ich noch die Datenpunkte/objects von den Tasmota Birnen durch den Sonoff Adapter (MQTT?), wie verbinde ich diese nun mit dem Schalter bzw. schaffe es, das keine extreme Verzögerung auftritt? (entweder direkt in Node-Red oder auch sonst wo)

                                So habe ich das in Blocky aktuell mit starker Verzögerung (6-7 Sekunden)

                                Screenshot_20200517-071725_Gallery.jpg

                                Kann mir da jemand bitte helfen? Bin da schon seit Tagen dran mit dem dämlichen Schalter und den Birnen ^^

                                1 Reply Last reply Reply Quote 0
                                • E
                                  extbingh last edited by Jey Cee

                                  ? Hat keiner Tasmota Birnen mit nem Schalter verbunden ^^

                                  Aphofis 1 Reply Last reply Reply Quote 0
                                  • Aphofis
                                    Aphofis @extbingh last edited by Aphofis

                                    @extbingh
                                    Ich stehe vor dem selben Problem

                                    Ich möchte auch mit einem hue Dimmer Switch
                                    Schalten
                                    Da soll aus 1002 dann True werden bei Short Release
                                    Und bei 1003 dann false werden bzw. noch besser wäre 1 Klick true noch mal Klick false aber wie man das realisiert weiß ich nicht
                                    Dazu muss aber der datenpunkt vom Switch ausgewertet werden. Ich hatte das bis jetzt in norde-red getestet und bis jetzt noch nicht erfolgreich gewesen.
                                    Hintergrund ich habe mehrere mehrfach Lichtschalter die ich mit Tuya Touch Lichtschaltern am laufen habe.
                                    Problem ist, Lichtschalter schaltet über Kabel das deckenlicht ein und parallel über node-red schaltet der Lichtschalter dann noch andere Lampen (hue, Tuya) dazu
                                    Wenn man nun den Lichtschalter zu schnell hintereinander klickt drehen die Lampen durch und ich habe Disko.
                                    Die Schaltungen beinhalten auch noch einen Hue bewegungsmelder der den Tuya Lichtschalter schaltet und nach 3 min. Wieder ausschaltet. Wenn Lichtschalter benutz wird bleibt Licht für 30 min. An. Wenn mein staubsaug Roboter fährt sich die bewegungsmelder deaktiviert.
                                    Nur wie man die buttonevent 1002,1003 etc. nun auswertet um daraus mit nur zb dem ersten Button dazu bringt ein Klick True zweiter Klick false weiß ich nicht
                                    Hatte dann versucht Shelly i4 gen3 dazu zu nutzen nur komme ich da auch nicht weiter. Da der Shelly keinen datenpunkt hat den man schalten kann auch wenn im Shelly direkt Sektionen für an und aus erstellt sind

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

                                    Support us

                                    ioBroker
                                    Community Adapters
                                    Donate

                                    1.0k
                                    Online

                                    31.7k
                                    Users

                                    79.7k
                                    Topics

                                    1.3m
                                    Posts

                                    9
                                    22
                                    7137
                                    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