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.
    • 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
                                • R
                                  RobS last edited by

                                  Hallo Brati,

                                  vielen Dank für deine Antwort. Jetzt habe ich es auch begriffen. Mir war nicht klar, dass die Homematicvariable einfach nur auf "True" gestellt wird.

                                  Danke nochmal und Gruß

                                  Rob

                                  Edit: Danke, noch für dein Edit und den Bildanhang, sieht Super aus!

                                  1 Reply Last reply Reply Quote 0
                                  • F
                                    Fugazzy last edited by

                                    Ich habe dieses Skript einmal auf meine Bedürfnisse angepasst und grundsätzlich funktioniert es auch:

                                    ! // WochenEnde Wecken
                                    ! var WEWeck = "50 8 * * 0,6"; // nur Samstag und Sonntag
                                    ! on(/^javascript.0.Jalousie.WochenEndWeckStunde|javascript.0.Jalousie.WochenEndWeckMinute/, function(obj) {
                                    ! clearSchedule(WEWeck);
                                    ! var id_wStunde = getState("javascript.0.Jalousie.WochenEndWeckStunde").val;
                                    ! var id_wMinute = getState("javascript.0.Jalousie.WochenEndWeckMinute").val;
                                    ! var WeckZeit = id_wMinute + ' ' + id_wStunde + ' * * 0,6';
                                    ! WEWeck = schedule(WeckZeit, function(){
                                    ! setState("scene.0.szene_JalousieSoll_Wecken"/0.szene_JalousieSoll_Wecken/, true);
                                    ! });
                                    ! });
                                    Aber was passiert nach einem Neustart von iobroker?

                                    Mir scheint, dann ist die Zeitsteuerung zunächst uninitialisiert, oder? Soll heissen nicht aktiv?

                                    Was muss ich tun, damit das auch einen Neustart überlebt?

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

                                      Das Problem mit dem Neustart hast du richtig erkannt, ich fange das mit internen Variablen ab. Kann ich aber erst morgen posten.

                                      Grüße Brati

                                      Gesendet via Tapatalk.

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

                                        Soo, also das Problem beim Neustart hatte ich auch, mein Workaround dazu:

                                        • Das Script wird ja bei jedem Neustart ausgeführt, die "States" bleiben erhalten.

                                        • Der Timer wird natürlich nicht gesetzt, weil sich ja nix ändert.

                                        • also schreibe ich mir die gesetzte Minute in eine Variable, ändere die Minute -> Timer wird gesetzt -> schreibe die Minute zurück -> Timer wird wieder richtig gesetzt.

                                        var Temp_Minute = getState("Timer.Wecker.XX.Minute").val;
                                        setState("Timer.Wecker.XX.Minute", 59);
                                        setState("Timer.Wecker.XX.Minute", Temp_Minute);
                                        

                                        Der Wert 59 Minuten ist bei mir nicht einstellbar, weil immer +/- 5min. Und so funktioniert es.

                                        Grüße

                                        Brati

                                        1 Reply Last reply Reply Quote 0
                                        • F
                                          Fugazzy last edited by

                                          wo hast du denn das eingebaut? Sollte ja nur bei einem Neustart ausgelöst werden, oder?

                                          Edit:

                                          Durch basteln an einer anderen Sachen hat sich eine Lösung ergeben:

                                          Ich habe eine (Status-)Variable, die immer neu angelegt wird mit dem Defaultwert false.

                                          Damit steuere ich, ob die Jalousie-Zeiten neu berechnet werden müssen, in diesem Fall wird sie auf true gesetzt.

                                          Die Auslösung der Berechnung geschieht immer auf Aktualisierung, (change:"any")

                                          und eben auch, wenn sie durch einen Neustart wieder auf false gesetzt wird

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

                                            Hallo,

                                            ich hatte weiter oben im Thread die Steuerung der Rollläden erwähnt. Sie werden zu einer festen Zeit geöffnet. Diese Zeit wird in paul53's Skript ja wunderbar in Stunde und Minute zerlegt und dann per on(time)-Funktion gestartet.

                                            Frage: Lässt sich das auch bis auf die Sekunde genau machen? Die Doku sagt nix dazu
                                            @[url=https://github.com/ioBroker/ioBroker.javascript#astro--function:

                                            ~~astro Funktion in ioBroker Javascript Github"]~~on({time: {hour: 12, minute: 30}}, function () {

                                            log((new Date()).toString() + " - Will be triggered at 12:30!");

                                            }); `

                                            Ich starte die Schließung der Rollläden per Astrofunktion (Sonnenuntergang). Diese lässt sich nicht ohne weiteres mit der on(time)-Funktion aufrufen. Diese on(time)-Funktion brauche ich aber, damit die clearSchedule-Funktion verwendet werden kann.

                                            Als lasse ich mir mit getAstroDate die Sonnenuntergangszeit ausrechnen und addiere/subtrahiere den in VIS eingegeben Shift dazu. Diese Zeit ist nun die Basis für die on(time)-Funktion. 261_bildschirmfoto_2016-11-15_um_18.32.53.jpg
                                            Die errechnete Zeit ist sekundengenau. Momentan nutze ich aber nur die Stunde und die Minute.

                                            ! ````
                                            // Schließen <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
                                            // per Astrofunktion abhängig vom Fensterstatus (Daten von Variable, nicht vom Gerät RHS)
                                            createState('Homepilot.Rollladen.Wohnzimmer.zu.Shift', 10, {
                                            type: 'number',
                                            unit: 'min',
                                            name: 'Wohnzimmer Rollläden Schließung Astrosteuerung - Shift in Minuten'
                                            });
                                            createState('Homepilot.Rollladen.Wohnzimmer.zu.Shift.Zeit', 10, {
                                            type: 'string',
                                            unit: 'Uhr',
                                            name: 'Wohnzimmer Rollläden tatsächliche Uhrzeit nächste Schließung per Astrosteuerung und Shift'
                                            });
                                            createState('Homepilot.Rollladen.Wohnzimmer.zu.Level', 95, {
                                            type: 'number',
                                            min: 0,
                                            max: 100,
                                            unit: '%',
                                            name: 'Wohnzimmer Rollläden Schließung Astrosteuerung - Level'
                                            });
                                            var idSchliessung_Shift = "javascript.0.Homepilot.Rollladen.Wohnzimmer.zu.Shift",
                                            idSchliessung_Zeit = "javascript.0.Homepilot.Rollladen.Wohnzimmer.zu.Shift.Zeit",
                                            idSchliessung_Level = "javascript.0.Homepilot.Rollladen.Wohnzimmer.zu.Level";
                                            ! // Variablen Definition für Schliessentimer per on()-Funktion
                                            var schliessen_timer = null;
                                            var schliessen_h;
                                            var schliessen_m;
                                            var schliessen_s;
                                            ! // wenn Shift in VIS verändert wurde, wird die neue Schließenzeit ausgerechnet
                                            function astro_shift_berechnen () {
                                            var astrotag = isAstroDay(),
                                            //sonnenaufgang, // spielt beim Schließen keine Rolle
                                            sonnenuntergang,
                                            astro_shift_zeit_zu,
                                            shift_minuten = parseFloat(getState(idSchliessung_Shift).val); // kann negativ sein
                                            var today = new Date();
                                            var tomorrow = today.setDate(today.getDate()+1);
                                            if (astrotag) { // Wenn Tag (Aufgang vorbei (erst wieder morgen, Untergang kommt noch heute)
                                            sonnenuntergang = getAstroDate('sunset', today);
                                            //sonnenaufgang = getAstroDate('sunrise', tomorrow);
                                            } else { // nach Nacht (Untergang vorbei (erst wieder morgen, Aufgang kommt heute oder morgen)
                                            sonnenuntergang = getAstroDate('sunset', tomorrow);
                                            //sonnenaufgang = (today.getHours() > 12 && today.getHours() <= 23) ? getAstroDate('sunrise', tomorrow) : getAstroDate('sunrise', today); // es ist vor Mitternacht (bzw. vor 23:XXUhr), dann morgen, sonst heute
                                            }
                                            astro_shift_zeit_zu = sonnenuntergang.setMinutes(sonnenuntergang.getMinutes() + shift_minuten);
                                            var neue_zeit = new Date(astro_shift_zeit_zu);
                                            //log(astro_shift_zeit_zu);
                                            //log(shift_minuten);
                                            //log(neue_zeit.toLocaleTimeString());
                                            setState(idSchliessung_Zeit, neue_zeit.toLocaleTimeString());

                                            // neue Schliessungszeit für Steuerung per on()-Funktion vorbereiten (vom 16.11.2016)
                                            setTimeout( function() {
                                                var time_array = getState(idSchliessung_Zeit).val.split(":");
                                                schliessen_h = parseInt(time_array[0], 10); // Stunden
                                                schliessen_m = parseInt(time_array[1], 10); // Minuten
                                                schliessen_s = parseInt(time_array[2], 10); // Sekunden
                                                log('Wohnzimmer Rollläden: Neue Schließenzeit gesetzt: ' + getState(idSchliessung_Zeit).val + ' Uhr');
                                                setSchliessenTimer();
                                            }, 2000);
                                            

                                            }

                                            ! function setSchliessenTimer() {
                                            if (schliessen_timer) clearSchedule(schliessen_timer);
                                            schliessen_timer = on({time: {
                                            hour: schliessen_h,
                                            minute: schliessen_m/, // <<<<<<< Sekunden möglich???
                                            second: schliessen_s
                                            /}
                                            }, function () {
                                            var level_rechts = getState(idRolloWZrechts_position).val,
                                            level_links = getState(idRolloWZlinks_position).val,
                                            level_soll = parseInt(getState(idSchliessung_Level).val, 10);
                                            if (level_rechts > level_soll) {
                                            //var fenster_rechts = getState(idStatusWZFensterrechts).val;
                                            //if (fenster_rechts != 2) {
                                            setTimeout(function () {
                                            setState(idRolloWZrechts_position, level_soll); // id rechts, 95%
                                            log('Rollladen WZ rechts wird herabgefahren - Astrosteuerung');
                                            }, 1000);
                                            //} else log('Rollladen Wohnzimmer Fenster rechts nicht herabgefahren, da Fenster offen');
                                            } else log('Rollladen Wohnzimmer rechts war bereits weiter als ' + level_soll + '% geschlossen, deshalb keine Bewegung');
                                            if (level_links > level_soll) {
                                            var fenster_links = getState(idStatusWZFensterlinks).val;
                                            if (fenster_links != 2) {
                                            setState(idRolloWZlinks_position, level_soll); // id links, 95%
                                            log('Rollladen WZ links wird herabgefahren - Astrosteuerung');
                                            } else log('Rollladen Wohnzimmer Fenster rechts nicht herabgefahren, da Fenster offen');
                                            } else log('Rollladen Wohnzimmer rechts war bereits weiter als ' + level_soll + '% geschlossen, deshalb keine Bewegung');

                                                //log('Rollladen WZ Fenster links wird derzeit noch nicht automatisch geschlossen');
                                            });
                                            

                                            }

                                            ! // Berechnung der Uhrzeit, wann Astrosunset und Shift
                                            // jede Stunde
                                            schedule('9 * * * *', astro_shift_berechnen);
                                            // oder bei Änderung der Eingabe von Shift
                                            on(idSchliessung_Shift, astro_shift_berechnen);

                                            
                                            Gruß
                                            
                                            Pix
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            755
                                            Online

                                            31.7k
                                            Users

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