Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. [gelöst]Dimmen mit "Long Press"

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    331

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.5k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.5k

[gelöst]Dimmen mit "Long Press"

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
39 Beiträge 8 Kommentatoren 6.7k Aufrufe 7 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • P Offline
    P Offline
    pix
    schrieb am zuletzt editiert von
    #2

    Hallo,

    kann kein Blockly, aber im Javascript Adapter geht das auch mit Skript:

    const idDimmer = "CC78CB0000uswuswIDhierEIntragen"; // HIER ID AKTOR/DIMMER nochmal eintragen
    const idPressLong = "mihome.0.devices.switch_158d0001f3a5b2.long";
    var zielwert = 0;
    
    on({id: idPressLong, val: true}, function (obj) {
        log("Tastendruck lang -> dimme " + idDimmer + " auf " + zielwert + " Prozent");
        setState(idDimmer, zielwert);
    }
    
    

    Gruß

    Pix

    ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

    1 Antwort Letzte Antwort
    0
    • L Offline
      L Offline
      loi83
      schrieb am zuletzt editiert von
      #3

      Hallo Pix

      Javascript kann ich nicht. ;)

      Ich schau mir das morgen früh mal an, danke dir schonmal.

      Gruß Michi

      1 Antwort Letzte Antwort
      0
      • L Offline
        L Offline
        loi83
        schrieb am zuletzt editiert von
        #4

        Guten Morgen

        Das Script funzt nicht. So wie ich es raus lesen kann fehlt eine Klammer irgendwo.
        5495_script_fehler.png

        Gruß Michi

        1 Antwort Letzte Antwort
        0
        • paul53P Offline
          paul53P Offline
          paul53
          schrieb am zuletzt editiert von
          #5

          @loi83:

          So wie ich es raus lesen kann fehlt eine Klammer irgendwo. `
          Ja, in der letzten Zeile. Richtig:

          });
          

          Was soll bei "Long Press" passieren ?

          Eine Rampe "hoch/runter" bis Taste losgelassen wird ? Wenn ja, in welcher Zeit von 0 auf 100 % ?

          Geht "Long Press" bei Loslassen der Taste auf false ?

          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

          1 Antwort Letzte Antwort
          0
          • L Offline
            L Offline
            loi83
            schrieb am zuletzt editiert von
            #6

            Hey

            ` > Was soll bei "Long Press" passieren ?

            Eine Rampe "hoch/runter" bis Taste losgelassen wird ? Wenn ja, in welcher Zeit von 0 auf 100 % ?

            Geht "Long Press" bei Loslassen der Taste auf false? `

            Bei "Long Press" soll ich eine Lampe Dimmen, bis der Taster losgelassen wird.

            Über eine zeitliche Begrenzung hab ich noch nicht nachgedacht, sollte schon zügig gehen.

            Ja, der Status geht zurück auf false beim loslassen.

            Gruß Michi

            1 Antwort Letzte Antwort
            0
            • paul53P Offline
              paul53P Offline
              paul53
              schrieb am zuletzt editiert von
              #7

              Vorschlag:

              const idLevel = "meinAdapter.0.CC78CB0000261884.bri"; // meinAdapter anpassen !
              const idSwitch = "meinAdapter.0.CC78CB0000261884.on"; // meinAdapter anpassen !
              const idLong = "mihome.0.devices.switch_158d0001f3a5b2.long";
              
              var level = getState(idLevel).val;
              var state = getState(idSwitch).val;
              var down = false;
              if(level > 90) down = true;
              var timer = null;
              
              function rampe() {
                 if(down) {
                    level = level - 5;
                    if(level < 0) down = false;
                    else setState(idLevel, level);
                 } else {
                    level = level + 5;
                    if(level > 100) down = true;
                    else setState(idLevel, level);
                 }
              }
              
              on({id: idSwitch, ack: true}, function(dp) {
                 state = dp.state.val;
              });
              
              on(idLong, function(dp) {
                 if(dp.state.val) {
                    if(!state) setState(idSwitch, true);
                    timer = setInterval(rampe, 200);
                 } else clearInterval(timer);
              });
              
              

              EDIT: switch –> state

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              1 Antwort Letzte Antwort
              0
              • L Offline
                L Offline
                loi83
                schrieb am zuletzt editiert von
                #8

                Deinen Vorschlag hab ich angenommen.

                Allerdings bringt er einen Fehler:
                5495_script_fehler.png

                Gruß Michi

                1 Antwort Letzte Antwort
                0
                • paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von
                  #9

                  Sorry, switch ist ein reserviertes Wort. Tausche bitte switch gegen state aus (Zeilen 6, 24, 29).

                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                  1 Antwort Letzte Antwort
                  0
                  • L Offline
                    L Offline
                    loi83
                    schrieb am zuletzt editiert von
                    #10

                    Der Wahsinn. Du bist genial, genauso hab ich mir es vorgestellt.

                    Hammer. Tausend Dank.

                    Gruß Michi

                    1 Antwort Letzte Antwort
                    0
                    • ? Offline
                      ? Offline
                      Ein ehemaliger Benutzer
                      schrieb am zuletzt editiert von
                      #11

                      Sorry wenn ich nochmal das Thema aufmache. Ich versuche das Script auf eine weitere Lampe zu erweitern. Hört sich simpel an aber anscheinend zu schwierig für mich ;-) Also die Aufgabe wäre ein Taster zwei Lampen die synchron laufen. Kann mir jemand einen Tipp geben?

                      K 1 Antwort Letzte Antwort
                      0
                      • ? Ein ehemaliger Benutzer

                        Sorry wenn ich nochmal das Thema aufmache. Ich versuche das Script auf eine weitere Lampe zu erweitern. Hört sich simpel an aber anscheinend zu schwierig für mich ;-) Also die Aufgabe wäre ein Taster zwei Lampen die synchron laufen. Kann mir jemand einen Tipp geben?

                        K Offline
                        K Offline
                        kszaboa
                        schrieb am zuletzt editiert von
                        #12

                        @noah3112 wenn die beiden Lampen immer synchron sich ändern sollen, könntest du es mit einem zusätzlichen, simplen blockly script erledigen: eine Lampe wäre der "Master", der mit Dimmer gesteuert wird, die andere der "Slave". Trigger: Brightness Änderung der Lampe, dann "mache: steuere Wert Brightness der zweiten Lampe mit Wert Brightness der ersten.

                        1 Antwort Letzte Antwort
                        0
                        • Vl DkV Offline
                          Vl DkV Offline
                          Vl Dk
                          schrieb am zuletzt editiert von
                          #13

                          Ist jemand so lieb und kann den Skript für den Xiaomi Aqara Wireless Mini Switch anpassen?
                          Bildschirmfoto 2020-05-27 um 23.40.25.png

                          1 Antwort Letzte Antwort
                          0
                          • R Offline
                            R Offline
                            R1Snake
                            schrieb am zuletzt editiert von
                            #14

                            @paul53 said in [gelöst]Dimmen mit "Long Press":

                            const idLevel = "meinAdapter.0.CC78CB0000261884.bri"; // meinAdapter anpassen ! const idSwitch = "meinAdapter.0.CC78CB0000261884.on"; // meinAdapter anpassen ! const idLong = "mihome.0.devices.switch_158d0001f3a5b2.long"; var level = getState(idLevel).val; var state = getState(idSwitch).val; var down = false; if(level > 90) down = true; var timer = null; function rampe() { if(down) { level = level - 5; if(level < 0) down = false; else setState(idLevel, level); } else { level = level + 5; if(level > 100) down = true; else setState(idLevel, level); } } on({id: idSwitch, ack: true}, function(dp) { state = dp.state.val; }); on(idLong, function(dp) { if(dp.state.val) { if(!state) setState(idSwitch, true); timer = setInterval(rampe, 200); } else clearInterval(timer); });

                            Ganz einfach

                            Nimm das Script:

                            const idLevel = "meinAdapter.0.CC78CB0000261884.bri"; // meinAdapter anpassen !
                            const idSwitch = "meinAdapter.0.CC78CB0000261884.on"; // meinAdapter anpassen !
                            const idLong = "mihome.0.devices.switch_158d0001f3a5b2.long";
                             
                            var level = getState(idLevel).val;
                            var state = getState(idSwitch).val;
                            var down = false;
                            if(level > 90) down = true;
                            var timer = null;
                             
                            function rampe() {
                               if(down) {
                                  level = level - 5;
                                  if(level < 0) down = false;
                                  else setState(idLevel, level);
                               } else {
                                  level = level + 5;
                                  if(level > 100) down = true;
                                  else setState(idLevel, level);
                               }
                            }
                             
                            on({id: idSwitch, ack: true}, function(dp) {
                               state = dp.state.val;
                            });
                             
                            on(idLong, function(dp) {
                               if(dp.state.val) {
                                  if(!state) setState(idSwitch, true);
                                  timer = setInterval(rampe, 200);
                               } else clearInterval(timer);
                            });
                            

                            In der dritten Zeile änderst du es auf :
                            const idLong = [Hier den Pfad von release_hold] eintragen

                            paul53P 1 Antwort Letzte Antwort
                            0
                            • R R1Snake

                              @paul53 said in [gelöst]Dimmen mit "Long Press":

                              const idLevel = "meinAdapter.0.CC78CB0000261884.bri"; // meinAdapter anpassen ! const idSwitch = "meinAdapter.0.CC78CB0000261884.on"; // meinAdapter anpassen ! const idLong = "mihome.0.devices.switch_158d0001f3a5b2.long"; var level = getState(idLevel).val; var state = getState(idSwitch).val; var down = false; if(level > 90) down = true; var timer = null; function rampe() { if(down) { level = level - 5; if(level < 0) down = false; else setState(idLevel, level); } else { level = level + 5; if(level > 100) down = true; else setState(idLevel, level); } } on({id: idSwitch, ack: true}, function(dp) { state = dp.state.val; }); on(idLong, function(dp) { if(dp.state.val) { if(!state) setState(idSwitch, true); timer = setInterval(rampe, 200); } else clearInterval(timer); });

                              Ganz einfach

                              Nimm das Script:

                              const idLevel = "meinAdapter.0.CC78CB0000261884.bri"; // meinAdapter anpassen !
                              const idSwitch = "meinAdapter.0.CC78CB0000261884.on"; // meinAdapter anpassen !
                              const idLong = "mihome.0.devices.switch_158d0001f3a5b2.long";
                               
                              var level = getState(idLevel).val;
                              var state = getState(idSwitch).val;
                              var down = false;
                              if(level > 90) down = true;
                              var timer = null;
                               
                              function rampe() {
                                 if(down) {
                                    level = level - 5;
                                    if(level < 0) down = false;
                                    else setState(idLevel, level);
                                 } else {
                                    level = level + 5;
                                    if(level > 100) down = true;
                                    else setState(idLevel, level);
                                 }
                              }
                               
                              on({id: idSwitch, ack: true}, function(dp) {
                                 state = dp.state.val;
                              });
                               
                              on(idLong, function(dp) {
                                 if(dp.state.val) {
                                    if(!state) setState(idSwitch, true);
                                    timer = setInterval(rampe, 200);
                                 } else clearInterval(timer);
                              });
                              

                              In der dritten Zeile änderst du es auf :
                              const idLong = [Hier den Pfad von release_hold] eintragen

                              paul53P Offline
                              paul53P Offline
                              paul53
                              schrieb am zuletzt editiert von
                              #15

                              @R1Snake sagte:

                              Hier den Pfad von release_hold

                              Ich würde vermuten, dass "release_hold" erst beim Loslassen true wird ?
                              Wie verhalten sich die Datenpunkte "hold" und "release_hold" (loggen) ?

                              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                              coyoteC 1 Antwort Letzte Antwort
                              0
                              • paul53P paul53

                                @R1Snake sagte:

                                Hier den Pfad von release_hold

                                Ich würde vermuten, dass "release_hold" erst beim Loslassen true wird ?
                                Wie verhalten sich die Datenpunkte "hold" und "release_hold" (loggen) ?

                                coyoteC Offline
                                coyoteC Offline
                                coyote
                                Most Active
                                schrieb am zuletzt editiert von
                                #16

                                @paul53 das Script kann man doch auch bestimmt umbauen für Homatic Dimmer, die haben keinen .on Datenpunkt. Gibt nur den .level Datenpunkt.

                                paul53P 1 Antwort Letzte Antwort
                                0
                                • coyoteC coyote

                                  @paul53 das Script kann man doch auch bestimmt umbauen für Homatic Dimmer, die haben keinen .on Datenpunkt. Gibt nur den .level Datenpunkt.

                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  schrieb am zuletzt editiert von
                                  #17

                                  @coyote sagte:

                                  Homatic Dimmer, die haben keinen .on Datenpunkt.

                                  Haben HM-Dimmer nicht einen .STATE Datenpunkt ? Dieser würde dem .on Datenpunkt entsprechen.

                                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                  coyoteC 1 Antwort Letzte Antwort
                                  0
                                  • paul53P paul53

                                    @coyote sagte:

                                    Homatic Dimmer, die haben keinen .on Datenpunkt.

                                    Haben HM-Dimmer nicht einen .STATE Datenpunkt ? Dieser würde dem .on Datenpunkt entsprechen.

                                    coyoteC Offline
                                    coyoteC Offline
                                    coyote
                                    Most Active
                                    schrieb am zuletzt editiert von
                                    #18

                                    @paul53 nein leider nicht.

                                    Dimmer.JPG

                                    paul53P 1 Antwort Letzte Antwort
                                    0
                                    • coyoteC coyote

                                      @paul53 nein leider nicht.

                                      Dimmer.JPG

                                      paul53P Offline
                                      paul53P Offline
                                      paul53
                                      schrieb am zuletzt editiert von
                                      #19

                                      @coyote sagte:

                                      nein leider nicht.

                                      Also sind die HM-Dimmer immer an und werden nur durch den LEVEL gesteuert ? Dann lasse alles mit Bezug auf idSwitch und der Variablen state weg.

                                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                      coyoteC 2 Antworten Letzte Antwort
                                      0
                                      • paul53P paul53

                                        @coyote sagte:

                                        nein leider nicht.

                                        Also sind die HM-Dimmer immer an und werden nur durch den LEVEL gesteuert ? Dann lasse alles mit Bezug auf idSwitch und der Variablen state weg.

                                        coyoteC Offline
                                        coyoteC Offline
                                        coyote
                                        Most Active
                                        schrieb am zuletzt editiert von
                                        #20

                                        @paul53 genau, werden nur über level gesteuert. Ok, werde ich testen. Danke dir.

                                        1 Antwort Letzte Antwort
                                        0
                                        • paul53P paul53

                                          @coyote sagte:

                                          nein leider nicht.

                                          Also sind die HM-Dimmer immer an und werden nur durch den LEVEL gesteuert ? Dann lasse alles mit Bezug auf idSwitch und der Variablen state weg.

                                          coyoteC Offline
                                          coyoteC Offline
                                          coyote
                                          Most Active
                                          schrieb am zuletzt editiert von coyote
                                          #21

                                          @paul53 unklar ist mir, was mit dem letzten Block ist, den brauche ich doch, damit ich überhaupt auf den LongPress reagiere, aber da ist state und switch drin. Den müsste man etwas umbauen oder?

                                          const idLevel = "meinAdapter.0.CC78CB0000261884.bri"; // meinAdapter anpassen !
                                          const idLong = "mihome.0.devices.switch_158d0001f3a5b2.long";
                                          
                                          var level = getState(idLevel).val;
                                          
                                          var down = false;
                                          if(level > 90) down = true;
                                          var timer = null;
                                          
                                          function rampe() {
                                             if(down) {
                                                level = level - 5;
                                                if(level < 0) down = false;
                                                else setState(idLevel, level);
                                             } else {
                                                level = level + 5;
                                                if(level > 100) down = true;
                                                else setState(idLevel, level);
                                             }
                                          }
                                          
                                          
                                          on(idLong, function(dp) {
                                             if(dp.state.val) {
                                                if(!state) setState(idSwitch, true);
                                                timer = setInterval(rampe, 200);
                                             } else clearInterval(timer);
                                          });
                                          

                                          Edit: Oder dann einfach die zweite if Zeile weg lassen?

                                          paul53P 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          324

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe