Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [GELÖST]on({time…..}) Aufruf

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [GELÖST]on({time…..}) Aufruf

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

      Hallo,

      hier mal meine Variante zum Thema.

      on("javascript.0.Weihnacht.Einschaltzeit", function(obj) {
          clearSchedule(schEin);
          var StdEin = getState("javascript.0.Weihnacht.Einschaltzeit").val.substr(0,2);
          var MinEin = getState("javascript.0.Weihnacht.Einschaltzeit").val.substr(3,2);
          var SchedStrEin = MinEin + ' ' + StdEin + ' * * 1-7';
          log("Einschaltzeit geändert auf: " + SchedStrEin);
          schEin = schedule(SchedStrEin, function(){
              log("Weihnachtsbeleuchtung ein per schedule");
              setState("javascript.0.Weihnacht.Beleuchtung",true,true);});
      });
      

      Ich hab's etwas anders gelöst. Ich weiß nicht, ob "schedule" besser oder schlechter ist als "on" - aber so hat das jedenfalls tadellos funktioniert.

      Ich weiß nicht, ob es bei Dir evtl. an der if-Bedingung vor dem unsubscribe liegen könnte…?? Ansonsten vielleicht auch mal den time-String vorher zusammensetzen und mit ins log schreiben lassen damit du siehst was da wirklich ankommt...???

      1 Reply Last reply Reply Quote 0
      • B
        Brati last edited by

        Morjens, dass mit der if Bedingungen schwebte mir nach dem Aufstehen auch durch den Kopf. Weil sie doch ohne Bedingungen auch keinen Sinn macht, es muss eh bei jeder Änderungen unsubcribe ausgeführt werden. Werde es mal testen. Grüße Brati

        Gesendet via Tapatalk.

        1 Reply Last reply Reply Quote 0
        • B
          Brati last edited by

          So, habe es jetzt auf Schedule umgestellt und das läuft perfekt. Ich lasse es noch 1 Woche im Log laufen, dann kommt der Echtbetrieb.

          Vielen Dank.

          Bei Interesse hier mein Script mit Wochenplan, den man flexibel ändern kann:

          // ##################### Wochenplan #####################
          schedule("00 12 * * *", function () {
          
          createState("Li_Stunde", 6);
          createState("Li_Minute", 30);
          
          //      Zeitplan  - wird jeden Tag um 12:00 Uhr für nächsten Tag gesetzt
          //                         M     D     M     D     F    S     S 
          //                         o     i     i     o     r    a     o
          //...................................................................
          var TagStunde = new Array("1",  "2",  "3",  "4",  "5", "12", "12");
          var TagMinute = new Array("10", "20", "30", "40", "50","00", "00");
          
              var jetzt = new Date();
              var tag = jetzt.getDay(); // Achtung Mo = 1, Array beginnt aber bei 0 -> daher nächster Tag
              if ( tag == "7" ) 
                  tag = "0"; 
              log ('Weckzeit morgen: ' + TagStunde[tag] + ':' + TagMinute[tag] + ' Uhr '+ "Tag= " + tag);
              setState("javascript.0.Li_Stunde",TagStunde[tag]);
              setState("javascript.0.Li_Minute",TagMinute[tag]);
          
          });
          
          // ##################### variable ZEITSTEUERUNG #####################
          var Li_Auf = "00 12 * * *";
          
          on(/^javascript.0.Li_Minute|javascript.0.Li_Stunde$/, function(obj) {
              clearSchedule(Li_Auf);
              var id_Stunde = getState("javascript.0.Li_Stunde").val,
          		id_Minute = getState("javascript.0.Li_Minute").val;
              var LiAufZeit = id_Minute + ' ' + id_Stunde + ' * * 1-7';
              log("Li Aufstehen geändert auf: " + LiAufZeit);
              Li_Auf = schedule(LiAufZeit, function(){
                  log("++++++++++ Test Aufsteh Script +++++ ");
               });
          });
          
          
          1 Reply Last reply Reply Quote 0
          • paul53
            paul53 last edited by

            @Brati:

            irgendwo habe ich einen Fehler im unsubscribe. Die Zeiten werden per Increase Widget verändert, also Stunde +/- 1 und Minuten +/-5. Jetzt habe ich die Zeit von 09:15 Uhr auf 09:00 gestellt, dass ergibt:

            Code: Alles auswählen

            javascript.0 2016-02-11 09:15:00 info javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++

            javascript.0 2016-02-11 09:10:01 info javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++

            javascript.0 2016-02-11 09:05:00 info javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++

            javascript.0 2016-02-11 09:00:00 info javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++

            Also alle 5min wurde beim runterstellen ein Timer eingetragen, aber nicht gelöscht. `
            unsubscribe(timer) funktioniert nicht ! Stattdessen muss clearSchedule(timer) verwendet werden:

            // Zeitsteuerung
            var idt = 'javascript.0.Test.Nachtruhe';
            var timer = null;
            var h; // Stunde
            var m; // Minute
            
            function settimer() {
                if (timer) clearSchedule(timer);
                timer = on({time: {hour: h, minute: m}}, function () {
                    log('Nachtruhe beginnt durch Schedulefunktion (Uhrzeit)');
                });
            }
            
            on(idt, function(dp) {
                var t = dp.newState.val.split(":");
                h = parseInt(t[0]);
                m = parseInt(t[1]);
                settimer(); 
                log("Beginn Nachtruhe wird eingestellt " + h + ":" + m);
            });
            
            
            1 Reply Last reply Reply Quote 0
            • paul53
              paul53 last edited by

              @blauholsten:

              Mach ich was falsch?

              Warum auch immer werden jetzt pünktlich jede Minute beide Funktionen aufgerufen, warum auch immer!!!??????? `
              Die Funktionen beginTimer() und endTimer() dürfen nicht bei Scriptstart aufgerufen werden, da bei Scriptstart die verwendeten Variablen auf null initialisert werden.

              1 Reply Last reply Reply Quote 0
              • paul53
                paul53 last edited by

                Hier noch eine Variante mit mehreren (im Beispiel 2) Zeitfunktionen:

                // Zeitsteuerung
                var idt1 = 'javascript.0.Test.Nachtruhe';
                var idt2 = "javascript.0.Test.Aufstehen";
                var timer1;
                var timer2;
                
                function getTimeObject(dp) {
                    var t = dp.newState.val.split(":");
                    var h = parseInt(t[0]);
                    var m = parseInt(t[1]);
                    return {hour: h, minute: m};    
                }
                
                on(idt1, function(dp) {
                    var t = getTimeObject(dp)
                    log("Beginn Nachtruhe wird eingestellt " + JSON.stringify(t));
                    if (timer1) clearSchedule(timer1);
                    timer1 = on({time: t}, function () {
                        log('Start Nachtruhe durch Schedulefunktion (Uhrzeit)');
                    });
                });
                
                on(idt2, function(dp) {
                    var t = getTimeObject(dp)
                    log("Aufstehen wird eingestellt " + JSON.stringify(t));
                    if (timer2) clearSchedule(timer2);
                    timer2 = on({time: t}, function () {
                        log('Start Aufstehen durch Schedulefunktion (Uhrzeit)');
                    });
                });
                
                
                1 Reply Last reply Reply Quote 0
                • B
                  Brati last edited by

                  Na auf die Antworten haben wir doch gewartet. Schedule hat den charmanten Vorteil Tage mit einzubinden. Hab mir noch ein 3. Array eingefügt. Auf jeden Fall gute Ansätze. Danke. Grüße Brati

                  Gesendet via Tapatalk.

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

                    @paul53:

                    @blauholsten:

                    Mach ich was falsch?

                    Warum auch immer werden jetzt pünktlich jede Minute beide Funktionen aufgerufen, warum auch immer!!!??????? Die Funktionen beginTimer() und endTimer() dürfen nicht bei Scriptstart aufgerufen werden, da bei Scriptstart die verwendeten Variablen auf null initialisert werden.

                    Hallo,

                    habe dein zuletzt gesendetes Skript übernommen, haut perfekt hin Danke!

                    Mir erschließt sich das trotzdem nicht warum die Funktionen im alten Skript jede Minute ausgeführt worden sind. Das Skript wir doch nicht jede Minute aufgerufen?ODER?

                    1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 last edited by

                      @blauholsten:

                      Mir erschließt sich das trotzdem nicht warum die Funktionen im alten Skript jede Minute ausgeführt worden sind. Das Skript wir doch nicht jede Minute aufgerufen?ODER? `
                      Nein., aber durch den Aufruf der Funktionen beim Scriptstart (letzte 2 Zeilen) wird an die on({time: …}-Funktion übergeben

                      on({time: {hour: null, minute: null}}, ...)
                      ````, was vermutlich zu dem beobachteten Verhalten führt.
                      1 Reply Last reply Reply Quote 0
                      • blauholsten
                        blauholsten Developer last edited by

                        @paul53:

                        @blauholsten:

                        Mir erschließt sich das trotzdem nicht warum die Funktionen im alten Skript jede Minute ausgeführt worden sind. Das Skript wir doch nicht jede Minute aufgerufen?ODER? `
                        Nein., aber durch den Aufruf der Funktionen beim Scriptstart (letzte 2 Zeilen) wird an die on({time: …}-Funktion übergeben

                        on({time: {hour: null, minute: null}}, ...)
                        ````, was vermutlich zu dem beobachteten Verhalten führt. `  
                        

                        …aber wenn ich danach die States mit Werten beschreibe, sollte es doch gehen? Hat es aber nicht

                        1 Reply Last reply Reply Quote 0
                        • paul53
                          paul53 last edited by

                          @blauholsten:

                          …aber wenn ich danach die States mit Werten beschreibe, sollte es doch gehen? Hat es aber nicht `
                          Dazu müssten die verwendeten Timer gelöscht werden, was aber mit unsubscribe(timer) nicht geschieht (es müsste clearSchedule(timer) sein).

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

                            so habe ich jetzt auch gemacht, bzw DU 😄 ; DANKE 😉

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

                              Hi Paul53,

                              ich habe wie im letzten Post dein Skript soweit übernommen. Haut auch soweit gut hin, aber das ganze wird nur 1mal ausgeführt!!!

                              Kann es sein, das durch meinen nächtlichen iobroker.restart(wegen Backup) die Variablen timer1 und 2 geleert werden, und dadurch das Speichern der on(time:…) auch leer ist?

                              Bitte nicht :lol: :lol: :lol: bin Anfänger.

                              Würde als Lösung gehen das ganze nicht an eine Variable zu übergeben, sondern an einen State?

                              EDITbzw macht es Sinn, die````
                              on(idt1, function(dp) {

                              on({id: idt1, change: "any"}, function(dp) {

                                ` > "ne" - bei Wertänderung
                              > 
                              > "any" - bei Aktualisierung (auch dann, wenn sich der Wert nicht ändert) ` 
                              1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 last edited by

                                @blauholsten:

                                Kann es sein, das durch meinen nächtlichen iobroker.restart(wegen Backup) die Variablen timer1 und 2 geleert werden, und dadurch das Speichern der on(time:…) auch leer ist? `
                                Ja.
                                @blauholsten:

                                Würde als Lösung gehen das ganze nicht an eine Variable zu übergeben, sondern an einen State? `
                                Die Funktionen müssen auch bei Scriptstart ausgeführt werden:

                                // Zeitsteuerung
                                var idt1 = 'javascript.0.Test.Nachtruhe';
                                var idt2 = "javascript.0.Test.Aufstehen";
                                var timer1;
                                var timer2;
                                
                                function getTimeObject(state) {
                                    var t = state.val.split(":");
                                    var h = parseInt(t[0]);
                                    var m = parseInt(t[1]);
                                    return {hour: h, minute: m};   
                                }
                                
                                on(idt1, function(dp) {
                                    var t = getTimeObject(dp.newState)
                                    log("Beginn Nachtruhe wird eingestellt " + JSON.stringify(t));
                                    if (timer1) clearSchedule(timer1);
                                    timer1 = on({time: t}, function () {
                                        log('Start Nachtruhe durch Schedulefunktion (Uhrzeit)');
                                    });
                                });
                                
                                on(idt2, function(dp) {
                                    var t = getTimeObject(dp.newState)
                                    log("Aufstehen wird eingestellt " + JSON.stringify(t));
                                    if (timer2) clearSchedule(timer2);
                                    timer2 = on({time: t}, function () {
                                        log('Start Aufstehen durch Schedulefunktion (Uhrzeit)');
                                    });
                                });
                                
                                // Scriptstart
                                var state = getState(idt1);
                                var t = getTimeObject(state)
                                if (timer1) clearSchedule(timer1);
                                timer1 = on({time: t}, function () {
                                     log('Start Nachtruhe durch Schedulefunktion (Uhrzeit)');
                                });
                                
                                state = getState(idt2);
                                t = getTimeObject(state)
                                if (timer2) clearSchedule(timer2);
                                timer2 = on({time: t}, function () {
                                     log('Start Aufstehen durch Schedulefunktion (Uhrzeit)');
                                });
                                
                                
                                1 Reply Last reply Reply Quote 0
                                • blauholsten
                                  blauholsten Developer last edited by

                                  Okay werde es probieren….und dann berichten.

                                  Könnte jemand trotzdem mal jemand erklären wann "any" dann anders ist als "ne". Bitte

                                  1 Reply Last reply Reply Quote 0
                                  • paul53
                                    paul53 last edited by

                                    @blauholsten:

                                    Könnte jemand trotzdem mal jemand erklären wann "any" dann anders ist als "ne". `
                                    Bei HM Funk-Temperatur-Sensoren wird bei "any" alle ca. 2,5 Minuten ausgelöst, auch dann, wenn sich der Temperaturwert nicht ändert, da der Sensor alle 2,5 Minuten den Wert sendet.

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

                                      DANKE…....

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

                                        Hi,

                                        wollte nur mal kurz eine Rückmeldung geben. Der zuletzt gesandte code funktioniert nach längeren erproben tadellos.

                                        … Danke an alle

                                        1 Reply Last reply Reply Quote 0
                                        • R
                                          RobS last edited by

                                          Hallo zusammen,

                                          ich möchte auch gerne einen Wecker per JavaScript umsetzen und dann per Widget steuern können.

                                          Dazu würde ich eines eurer Zeitsteuerungsscripte übernehmen. Allerdings ist mir nicht ganz klar, wie ich die Variablen überhaupt setze…

                                          Momentan nutze ich eine Homematicvariable, die ich in WebUI per Programm mit einer Uhrzeit füttere um morgens ein Script zu starten.

                                          Wäre nett, wenn mir jemand von euch mal eine Anleitung für Dummies geben könnte.

                                          Vielen Dank, Gruß

                                          Rob

                                          1 Reply Last reply Reply Quote 0
                                          • B
                                            Brati last edited by

                                            Hallo,

                                            ich stelle dir mal meine Lösung vor. Geschaltet wird damit eine Systemvariable "Wecker X" auf "true". In der CCU reagiere ich unter folgenden Bedingungen darauf:

                                            • "Wecker X" auf wahr - auf Änderung

                                            (Ich prüfe dann noch auf Urlaub, Anwesenheit, Ferien usw. aber das ist ja individuell). Dann wird das Programm abgearbeitet und die Variable auf "false" gesetzt.

                                            Im ioBroker ändere ich mittels dem Increas Widget den Status "Stunde" bzw. "Minute". Darauf reagiert das Script bzw. jeden Tag um 09:00 Uhr stelle ich den Wecker auf den regelmäßigen Zeitplan.
                                            709_zwischenablage01.jpg

                                            (Ich hab noch einen Fehler beim ersten Start nach 09 Uhr drin, dann wird die Zeit setzen Funktion nicht aufgerufen und ich drücke einmal Stunde hoch/ runter, muss ich mal reindenken und fixen).

                                            • edit vom 26.02.16 Das Script löst bei mir 9min vor dem Aufstehen aus, wegen Dimmzeit, dass habe ich hier entfernt.
                                            // ##################### Wochenplan #####################
                                            schedule("10 9 * * *", function () {
                                            
                                            createState("Timer.Wecker.X.Stunde", 6);
                                            createState("Timer.Wecker.X.Minute", 30);
                                            
                                            //      Zeitplan  - wird jeden Tag um 09:00 Uhr für nächsten Tag gesetzt
                                            //                         0     1     2     3     4    5     6      
                                            //                         M     D     M     D     F    S     S 
                                            //                         o     i     i     o     r    a     o
                                            //...................................................................
                                            var TagStunde = new Array("6",  "6",  "6",  "6",  "6", "12", "12");
                                            var TagMinute = new Array("30", "30", "45", "45", "30","00", "00");
                                            
                                                var jetzt = new Date();
                                                var tag = jetzt.getDay(); // Achtung Mo = 1, Arry beginnt aber bei 0 
                                                if ( tag == "7" ) 
                                                    tag = "0"; 
                                                log ('Weckzeit X morgen: ' + TagStunde[tag] + ':' + TagMinute[tag] + ' Uhr');
                                                setState("javascript.0.Timer.Wecker.X.Stunde",TagStunde[tag]);
                                                setState("javascript.0.Timer.Wecker.X.Minute",TagMinute[tag]);
                                            
                                            });
                                            
                                            // ##################### variable ZEITSTEUERUNG #####################
                                            var He_Auf = "00 12 * * *";
                                            
                                            on(/^javascript.0.Timer.Wecker.X.Stunde|javascript.0.Timer.Wecker.X.Minute/, function(obj) {
                                                clearSchedule(He_Auf);
                                                var id_Stunde = getState("javascript.0.Timer.Wecker.X.Stunde").val,
                                            	AufZeit = id_Minute + ' ' + id_Stunde + ' * * *';
                                                log("X Aufstehen geändert auf: " + AufZeit);
                                                He_Auf = schedule(AufZeit, function(){
                                                    log("++++++++++ Test Aufsteh Script X+++++ ");
                                                    setState("hm-rega.0.25880"/*X Wecker*/,true);
                                                });
                                            });
                                            
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.1k
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            11
                                            54
                                            11279
                                            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