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.
    • blauholsten
      blauholsten Developer last edited by

      Wenn ich nicht total blind bin geht die ganze Geschichte doch nicht wirklich…..

      mein Script:

      var nighttime = null;
      var morningtime = null;
      var idvon = 'javascript.0.visstates.nachtruhe.von';
      var idbis = 'javascript.0.visstates.nachtruhe.bis';
      var hvon;
      var mvon;
      var hbis;
      var mbis;
      
      function beginTimer()
      {
          if(nighttime)
          {
              unsubscribe(nighttime);
          }
          nighttime = on({time: {hour: hvon, minute: mvon}}, function()
          {
              setState("javascript.0.visstates.nachtruhe.nachtruhe", true);
              toLog("-->Nachtruhe begonnen", true);
          });
      }
      
      function endTimer()
      {
          if(morningtime)
          {
              unsubscribe(morningtime);
          }
          morningtime = on({time: {hour: hbis, minute: mbis}}, function()
          {
              setState("javascript.0.visstates.nachtruhe.nachtruhe", false);
              toLog("-->Nachtruhe beendet", true);
          });
      }
      
      on(idvon, function(dp) {
          var t = dp.newState.val.split(":");
          hvon = parseInt(t[0]);
          mvon = parseInt(t[1]);
          beginTimer(); 
          log("Beginn Nachtruhe wird eingestellt " + hvon + ":" + mvon);
      });
      
      on(idbis, function(dp) {
          var t = dp.newState.val.split(":");
          hbis = parseInt(t[0]);
          mbis = parseInt(t[1]);
          endTimer(); 
          log("Beginn Nachtruhe wird eingestellt " + hbis + ":" + mbis);
      });
      
      beginTimer();
      endTimer();
      
      

      Jetzt wird einfach die jeweilige Funktion jede Minute ausgeführt, obwohl die on Function vorher gar nicht aufgerufen worden ist, bzw. die Zeiten gar nicht gesetzt sind.

      671_unbenannt1.png
      671_unbenannt.png

      Mach ich was falsch?

      Warum auch immer werden jetzt pünktlich jede Minute beide Funktionen aufgerufen, warum auch immer!!!???????

      1 Reply Last reply Reply Quote 0
      • M
        mctom last edited by

        Hi,

        Hast du mal probiert die Zeit in folgendem Format einzugeben: hh:mm und nicht: hh:mm:ss. Das ist ein Unterschied zu mir der mir auf den ersten Blick aufgefallen.

        Gruß

        Michael

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

          wie mache ich das?

          671_unbenannt.png

          1 Reply Last reply Reply Quote 0
          • M
            mctom last edited by

            ich habe jetzt das Widget basic - Input val genommen.

            Hier kann man die Uhrzeit dann manuell eingeben.

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

              Hallo,

              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:

              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. Kann mir jemand helfen? (State wurde vorher schon definiert, weil eine Standard Zeittabelle vorgegeben ist, die individuell anpassbar sein soll).

              // ##################### ZEITSTEUERUNG #####################
              var FirstTimer = null;
              
              // Aufstehen morgens 
              
              var id_Stunde = "javascript.0.Li_Stunde",
                  id_Minute = "javascript.0.Li_Minute";
              
              function Li_Aufstehen () {
                   // Aufweckvariable setzen
                 log('+++++++++++++++++ Script Test aufstehen ++++++++++++++++++');
              }
              
              function setFirstTimer() {
                  if (FirstTimer) unsubscribe(FirstTimer);
                  FirstTimer = on({
                      time: {
                          hour: parseInt(getState(id_Stunde).val, 10), 
                          minute: parseInt( getState(id_Minute).val, 10)
                      }
                  }, function () {
                     Li_Aufstehen();
                  });
              }
              
              on({id: id_Stunde,change: 'ne'}, function(obj) { 
                  setFirstTimer(); 
              });
              
              on({id: id_Minute, change: 'ne'} , function(obj) {
                  setFirstTimer(); 
              });
              
              setFirstTimer();
              
              

              Grüße

              Brati

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

                Hi,

                das ist bei mir genau so! Leider…

                Es ist so als würde im "Bauch" alles gespeichert was man eingegeben hat. Sind dann alle Werte abgearbeitet, wird die eigentliche on (time..... Funktion nicht mehr ausgeführt, obwohl die Werte noch in den Datenpunkten stehen.

                Wollte das verhalten die letzten Tage schon hier Posten, hatte es dann aber vergessen.

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

                  @blauholsten:

                  Hi,

                  das ist bei mir genau so! Leider… `

                  Dann müßte ja "Pix" auch diesen Fehler haben, an seiner Idee habe mich orientiert. Der WAF sinkt gewaltig, wenn man später aufstehen will und dann früher und alle 5min geweckt wird lol
                  314_unbenannt.jpg

                  1 Reply Last reply Reply Quote 0
                  • P
                    pix last edited by

                    Hallo,

                    Ich bin gerade unterwegs und kann nicht testen. Ich nutze das für meine Rollläden und da klappt es.

                    Gesendet mit Tapatalk

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

                      Auch wenn die Zeit erhöht wird? Also später geöffnet wird? Nur dann würde man es merken.

                      Noch läuft es ja als Test bei mir.

                      Gesendet via Tapatalk.

                      1 Reply Last reply Reply Quote 0
                      • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.0k
                                            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