NEWS
[GELÖST]on({time…..}) Aufruf
-
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.
-
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 -
Hallo,
Ich bin gerade unterwegs und kann nicht testen. Ich nutze das für meine Rollläden und da klappt es.
Gesendet mit Tapatalk
-
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.
-
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...???
-
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.
-
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 +++++ "); }); });
-
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); });
-
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. -
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)'); }); });
-
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.
-
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?
-
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 übergebenon({time: {hour: null, minute: null}}, ...) ````, was vermutlich zu dem beobachteten Verhalten führt.
-
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 übergebenon({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
-
…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). -
so habe ich jetzt auch gemacht, bzw DU
; DANKE
-
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) `
-
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)'); });
-
Okay werde es probieren….und dann berichten.
Könnte jemand trotzdem mal jemand erklären wann "any" dann anders ist als "ne". Bitte
-
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.