NEWS
Dynamisches Licht - Farbverlauf Tag/Nacht
-
Ich hab bewusst 21 Uhr genommen, weil ich möchte, dass um diese Uhrzeit die Lampen den tiefsten Kelvinwert erreichen. In dem Astroskript, war die Nacht irgendwo bei 1 Uhr Nachts angesetzt und das war mir zu spät.
Das mit den Zeiten ist mir bisher nicht aufgefallen. Hab hier noch ein weiteres Astroskript am laufen und das zeigt mir die gleiche Uhrzeit an, nur als am/pm. Daher hab ich mich auf die Suche nach einem neuen Skript, dass mir die Zeiten als 24h Format anzeigt. Macht die Berechnung deutlich einfacher.
Wenn wir schon bei der Berechnung sind:
Ich werte die Uhrzeiten nicht anhand den Datenpunkten mit "Tageszeit" und "nächste Tageszeit" aus, sondern direkt an den Zeiten. Der Datenpunkt "Tageszeit" nutze ich nur als Aktualisierung der Berechnung. Wobei mir da auch schon aufgefallen ist, dass er da hin und wieder Probleme macht, weil zwischen drin Tageszeiten kommen, die es nicht gibt. Also er macht eine neue Berechnung, obwohl das gar nicht notwendig ist.
Ich nehme mal alle Tageszeiten mit rein und probiere es mal aus. -
@el_malto
Hier ist eine neue Version. Die If Schleifen sind nun zu einer zusammengefasst.Bei mir wird der Prozess nur unterbrochen, wenn in der Tageszeit auch ein richtiger Name drin steht. Andere Werte werden ignoriert.
Probier das mal bitte aus und gib mir ein Feedback, wie es bei dir ist.createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung', { name: 'Morgendämmerung', unit: 'K', type: 'number', def: 2700, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang', { name: 'Sonnenaufgang', unit: 'K', type: 'number', def: 4000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag', { name: 'Vormittag', unit: 'K', type: 'number', def: 5500, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag', { name: 'Mittag', unit: 'K', type: 'number', def: 5000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend', { name: 'Abend', unit: 'K', type: 'number', def: 4500, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung', { name: 'Abenddämmerung', unit: 'K', type: 'number', def: 3000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht', { name: 'Nacht', unit: 'K', type: 'number', def: 2100, }); createState('javascript.0.Dynamisches_Licht.Hilfswert_Kelvin', { name: 'Hilfswert_Kelvin', unit: 'K', type: 'number', }); //Startwert setzen für Hilfswert_Kelvin setTimeout(function() { if (getState("javascript.0.Astro.Tageszeit.current").val == 'Morgendämmerung'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Sonnenaufgang'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Vormittag'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Mittag'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abend'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abenddämmerung'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val);} },15000); var Hilfswert_Zeiten, i, Intervall1, Z_C3_A4hler_Schleife; // Tageszeit überprüfen on({id: "javascript.0.Astro.Tageszeit.current", change: "any"}, function (obj) { var value = obj.state.val; var oldValue = obj.oldState.val; //Morgendämmerung if (getState("javascript.0.Astro.Tageszeit.current").val == 'Morgendämmerung') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.12 - dawn").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.11 - nauticalDawn").val); return v.getHours() * 60 + v.getMinutes();})(); // nächste Astrozeit minus aktuellen Astrozeit in min i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val) / Hilfswert_Zeiten)*10)/10; // i = Die Höhe der Schritte um die Kelvinzahl anzupassen setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val);} //Startwert für Hilfswert_Kelvin //Sonnenaufgang else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Sonnenaufgang') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.03 - goldenHourEnd").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.12 - dawn").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val);} //Vormittag else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Vormittag') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.04 - solarNoon").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.03 - goldenHourEnd").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val);} //Mittag else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Mittag') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.05 - goldenHour").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.04 - solarNoon").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val);} //Abend else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abend') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.09 - nauticalDusk").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.05 - goldenHour").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val);} //Abenddämmerung else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abenddämmerung') { Hilfswert_Zeiten = (function () {var v = getDateObject('21:00'); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.09 - nauticalDusk").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val);} }); //Wert setzen Intervall1 = setInterval (function () { setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", (Math.round(getState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin").val + i))); // Hilfswert Kelvin ist ein Datenpunkt für die Übergabe an die Leuchten Z_C3_A4hler_Schleife = (typeof Z_C3_A4hler_Schleife == 'number' ? Z_C3_A4hler_Schleife : 0) + 1; if (Z_C3_A4hler_Schleife >= Hilfswert_Zeiten) { (function () {if (Intervall1) {clearInterval(Intervall1); Intervall1 = null;}})(); Z_C3_A4hler_Schleife = 0; } }, 60000); console.log(Z_C3_A4hler_Schleife); console.log(i); console.log(Hilfswert_Zeiten);
-
@lalalalala
Hab jetzt das Skript seit gestern Abend drin. Es schreibt bei wechsel der Tageszeit immer den Kelvin Wert in "Hilfswert_Kelvin" aber ändern den nicht. So als wenn die Berechnung nicht mehr funktioniert.EDIT: Hab jetzt mal alle Zeilenumbrücke gelöscht und nun ändern sich die Kelvini Werte wieder.
https://forum.iobroker.net/topic/26030/code-einfügen-fehlerhaftEDIT2: Hat aber mit den Zeilenumbrüchen nicht wirklich was zu tun. Das Skript hat wieder angehalten die Werte zu ändern.
-
ich hab das Gefühl, die Berechnung bzw das Intervall wird nicht mehr ausgeführt. Es zeigt mir auch eine Fehlermeldung mit "cannot find name interval" an. Das war vorher nicht so.
Daher hab ich mal ein Schedule daraus gemacht, der jede Minute ausgeführt wird.schedule("* * * * *", function () { setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", (Math.round(getState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin").val + i))); // Hilfswert Kelvin ist ein Datenpunkt für die Übergabe an die Leuchten Z_C3_A4hler_Schleife = (typeof Z_C3_A4hler_Schleife == 'number' ? Z_C3_A4hler_Schleife : 0) + 1; if (Z_C3_A4hler_Schleife >= Hilfswert_Zeiten) { (function () {if (Intervall1) {clearInterval(Intervall1); Intervall1 = null;}})(); Z_C3_A4hler_Schleife = 0; } });
Kannst du den bei dir unten anhängen bzw das alte ersetzen? Oder erkennst du durch die Zeilenumbrüche nichts mehr?
-
@lalalalala
Hab ich drunter gepackt und die komplette alteIntervall1 = setInterval(function ()
auskommentiert. Ich lass es jetzt mal den Tag über laufen.
-
Bei mir lief es heute den ganzen Tag durch.
Dabei ist mir aufgefallen, dass ich keinen Stop drin habe und daher die Schedule Schleife unendlich lang läuft.
Ich hab zwar herausgefunden, wie ich den Scheduler stoppen kann aber leider nicht, wie er wieder startet. Daher bin ich zurück auf das Intervall.
Das Intervall selbst ist nun eine eigene Funktion, die von den Tageszeiten gestartet wird. Stoppen tut es, sobald die Schleifenzahl erreicht ist.Werden bei dir die Kelvinwerte an die Lampen übergeben? Das hab ich nämlich leider noch nicht gelöst.
Hier nochmal das komplette Skript.
createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung', { name: 'Morgendämmerung', unit: 'K', type: 'number', def: 2700, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang', { name: 'Sonnenaufgang', unit: 'K', type: 'number', def: 4000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag', { name: 'Vormittag', unit: 'K', type: 'number', def: 5500, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag', { name: 'Mittag', unit: 'K', type: 'number', def: 5000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend', { name: 'Abend', unit: 'K', type: 'number', def: 4500, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung', { name: 'Abenddämmerung', unit: 'K', type: 'number', def: 3000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht', { name: 'Nacht', unit: 'K', type: 'number', def: 2100, }); createState('javascript.0.Dynamisches_Licht.Hilfswert_Kelvin', { name: 'Hilfswert_Kelvin', unit: 'K', type: 'number', }); //Startwert setzen für Hilfswert_Kelvin setTimeout(function() { if (getState("javascript.0.Astro.Tageszeit.current").val == 'Morgendämmerung'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Sonnenaufgang'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Vormittag'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Mittag'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abend'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abenddämmerung'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val);} },15000); var Hilfswert_Zeiten, i, Intervall1, Z_C3_A4hler_Schleife, Interval; // Tageszeit überprüfen on({id: "javascript.0.Astro.Tageszeit.current", change: "any"}, function (obj) { var value = obj.state.val; var oldValue = obj.oldState.val; //Morgendämmerung if (getState("javascript.0.Astro.Tageszeit.current").val == 'Morgendämmerung') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.12 - dawn").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.11 - nauticalDawn").val); return v.getHours() * 60 + v.getMinutes();})(); // nächste Astrozeit minus aktuellen Astrozeit in min i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val) / Hilfswert_Zeiten)*10)/10; // i = Die Höhe der Schritte um die Kelvinzahl anzupassen setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val); //Startwert für Hilfswert_Kelvin Z_C3_A4hler_Schleife = 0; startInt (); } //Sonnenaufgang else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Sonnenaufgang') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.03 - goldenHourEnd").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.12 - dawn").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val); Z_C3_A4hler_Schleife = 0; startInt (); } //Vormittag else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Vormittag') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.04 - solarNoon").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.03 - goldenHourEnd").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val); Z_C3_A4hler_Schleife = 0; startInt (); } //Mittag else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Mittag') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.05 - goldenHour").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.04 - solarNoon").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val); Z_C3_A4hler_Schleife = 0; startInt (); } //Abend else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abend') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.09 - nauticalDusk").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.05 - goldenHour").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val); Z_C3_A4hler_Schleife = 0; startInt (); } //Abenddämmerung else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abenddämmerung') { Hilfswert_Zeiten = (function () {var v = getDateObject('21:00'); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.09 - nauticalDusk").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val); Z_C3_A4hler_Schleife = 0; startInt (); } console.log(Z_C3_A4hler_Schleife); console.log(i); console.log(Hilfswert_Zeiten); }); startInt = function() { Interval = setInterval(function() { setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", (Math.round(getState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin").val + i))); // Hilfswert Kelvin ist ein Datenpunkt für die Übergabe an die Leuchten Z_C3_A4hler_Schleife = (typeof Z_C3_A4hler_Schleife == 'number' ? Z_C3_A4hler_Schleife : 0) + 1; if (Z_C3_A4hler_Schleife >= Hilfswert_Zeiten) { clearInterval (Interval); Z_C3_A4hler_Schleife = 0; return } }, 60000); };
-
@lalalalala
Bei mir hat das Skript auch wieder Probleme gemacht. Teste jetzt dein Skript über den Tag.Ich übergebe die Kelvin Werte noch nicht. Will erstmal das Skript vernüftig zum laufen bringen. Dazu kommt noch, dass meine Tradfri keine Kelvin Werte kann. Die kann nur RGB. Muss also später mal überlegen wie ich das umrechnen kann oder so.
-
Bei mir Läuft das Skript überhaupt nicht.
-
@el_malto sagte in Dynamisches Licht - Farbverlauf Tag/Nacht:
Bei mir Läuft das Skript überhaupt nicht.
Das muss ich doch berichtigen. Hatte dein Skript wohl falsch verstanden bzw. gelesen (kann leider so gut wie kein js). Hatte immer gedacht, dass das Skript durch arbeitet. Also auch Nachts. Das ist wohl nicht so oder? Bis jetzt läuft es seit gestern Abend. Ich beobachte weiter.
-
@lalalalala
Habe das Skript von dir jetzt zwei Tage getestet.
Leider stoppt das Skript bei erreichen des Kelvin Wertes nicht. Der Wert ging schon bis -300. -
ich war über das Wochenende nicht daheim.
Hab heute Morgen mal bei mir nachgeschaut und auf dem ersten Blick sieht es bei mir gut aus. Werde mich heute Abend nochmal dran hocken und schauen, woran es liegen könnte, dass es bei dir nicht stoppt. -
@lalalalala
Ich hab mir den "Hilfswert_Kelvin" und die Tageszeiten "current" und "next" bei Änderung immer per Telegram schicken lassen, um mal zwei Tage einen Verlauf zu sehen wie hoch und wie weit runter der geht (sind zwar massig Nachrichten aber die musste man dann einfach mal ignorieren).
Der niedrichste Wert von 2100 Kelvin (was ja bei Nacht sein soll), wurde um 20:39 Uhr erreicht. Dann hat das Skript aber nicht gestoppt und lief munter weiter bis morgens um 05:14 Uhr und da war der Wert dann auf -1350 Kelvin. Um 05:14 Uhr ist dann die Tageszeit "Mordendämmerung" gesetzt worden und der richtige Hilfwert_Kelvin von 2700 wurde gesetzt. Von da an ist der Wert dann wieder gestiegen. Aber auch wieder über den Wert hinaus bis 6165 Kelvin bis um 06:40 Uhr wieder die Tageszeit geändert wurde auf Sonnenaufgang und dann wieder der richtige Hilfswert von 4000 Kelvini gesetzt wurde. Dieser stieg dann auch wieder munter weiter bis 7230 Kelvin. Also auch wieder übers Zieh hinaus bis um 09:06 Uhr wieder bei Änderung der Tageszeit wieder der korrekte Hilfswert gesetzt wurde. Dann ist der Kelvin Wert aber gesunken, und das um 09:06 Uhr morgens. Da müsste der eigentlich steigen.Also irgendwas passt da noch nicht so ganz
-
Ich lass es per History aufzeichnen. Und da sieht alles gut aus. Bist du dir sicher, dass du das Skript richtig kopiert hast?
Ich habs dir hier nochmal:
createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung', { name: 'Morgendämmerung', unit: 'K', type: 'number', def: 2700, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang', { name: 'Sonnenaufgang', unit: 'K', type: 'number', def: 4000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag', { name: 'Vormittag', unit: 'K', type: 'number', def: 5500, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag', { name: 'Mittag', unit: 'K', type: 'number', def: 5000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend', { name: 'Abend', unit: 'K', type: 'number', def: 4500, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung', { name: 'Abenddämmerung', unit: 'K', type: 'number', def: 3000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht', { name: 'Nacht', unit: 'K', type: 'number', def: 2100, }); createState('javascript.0.Dynamisches_Licht.Hilfswert_Kelvin', { name: 'Hilfswert_Kelvin', unit: 'K', type: 'number', }); //Startwert setzen für Hilfswert_Kelvin setTimeout(function() { if (getState("javascript.0.Astro.Tageszeit.current").val == 'Morgendämmerung'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Sonnenaufgang'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Vormittag'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Mittag'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abend'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abenddämmerung'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val);} },15000); var Hilfswert_Zeiten, i, Intervall1, Z_C3_A4hler_Schleife, Interval; // Tageszeit überprüfen on({id: "javascript.0.Astro.Tageszeit.current", change: "any"}, function (obj) { var value = obj.state.val; var oldValue = obj.oldState.val; //Morgendämmerung if (getState("javascript.0.Astro.Tageszeit.current").val == 'Morgendämmerung') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.12 - dawn").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.11 - nauticalDawn").val); return v.getHours() * 60 + v.getMinutes();})(); // nächste Astrozeit minus aktuellen Astrozeit in min i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val) / Hilfswert_Zeiten)*10)/10; // i = Die Höhe der Schritte um die Kelvinzahl anzupassen setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val); //Startwert für Hilfswert_Kelvin Z_C3_A4hler_Schleife = 0; startInt (); } //Sonnenaufgang else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Sonnenaufgang') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.03 - goldenHourEnd").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.12 - dawn").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val); Z_C3_A4hler_Schleife = 0; startInt (); } //Vormittag else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Vormittag') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.04 - solarNoon").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.03 - goldenHourEnd").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val); Z_C3_A4hler_Schleife = 0; startInt (); } //Mittag else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Mittag') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.05 - goldenHour").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.04 - solarNoon").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val); Z_C3_A4hler_Schleife = 0; startInt (); } //Abend else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abend') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.09 - nauticalDusk").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.05 - goldenHour").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val); Z_C3_A4hler_Schleife = 0; startInt (); } //Abenddämmerung else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abenddämmerung') { Hilfswert_Zeiten = (function () {var v = getDateObject('21:00'); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.09 - nauticalDusk").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val); Z_C3_A4hler_Schleife = 0; startInt (); } console.log(Z_C3_A4hler_Schleife); console.log(i); console.log(Hilfswert_Zeiten); }); startInt = function() { Interval = setInterval(function() { setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", (Math.round(getState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin").val + i))); // Hilfswert Kelvin ist ein Datenpunkt für die Übergabe an die Leuchten Z_C3_A4hler_Schleife = (typeof Z_C3_A4hler_Schleife == 'number' ? Z_C3_A4hler_Schleife : 0) + 1; if (Z_C3_A4hler_Schleife >= Hilfswert_Zeiten) { clearInterval (Interval); Z_C3_A4hler_Schleife = 0; return } }, 60000); };
-
@lalalalala
Ja bin mir eigentlich sicher. Kopiere es jetzt noch mal und teste es. -
Bin heute nochmal alles einzeln durch.
Hab nun das Beenden der Schleife durch eine weiter Bedienung angepasst. Wird nun gestoppt, wenn die Zahl der Durchgänge oder der Ziel Kelvinwert erreicht wurde. So müsste es viel zuverlässiger sein.Ich hab auch ein paar Log Einträge eingebaut, einfach nur damit man jetzt am Anfang es besser nachvollziehen kann, was passiert oder auch nicht.
Kann man ja jederzeit raus kommentieren.Ebenso runde ich nun den Wert für die Erhöhung "i" immer auf.
Führt dazu, dass der Endwert früher erreicht wird aber finde das besser wie anders herum.Jetzt mal schauen, ob diese Version nun besser funktioniert.
Bin natürlich offen für VerbesserungencreateState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung', { name: 'Morgendämmerung', unit: 'K', type: 'number', def: 2700, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang', { name: 'Sonnenaufgang', unit: 'K', type: 'number', def: 4000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag', { name: 'Vormittag', unit: 'K', type: 'number', def: 5500, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag', { name: 'Mittag', unit: 'K', type: 'number', def: 5000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend', { name: 'Abend', unit: 'K', type: 'number', def: 4500, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung', { name: 'Abenddämmerung', unit: 'K', type: 'number', def: 3000, }); createState('javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht', { name: 'Nacht', unit: 'K', type: 'number', def: 2100, }); createState('javascript.0.Dynamisches_Licht.Hilfswert_Kelvin', { name: 'Hilfswert_Kelvin', unit: 'K', type: 'number', }); //Startwert setzen für Hilfswert_Kelvin setTimeout(function() { if (getState("javascript.0.Astro.Tageszeit.current").val == 'Morgendämmerung'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Sonnenaufgang'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Vormittag'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Mittag'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abend'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val);} else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abenddämmerung'){ setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val);} },15000); var Hilfswert_Zeiten, i, Intervall1, Z_C3_A4hler_Schleife, Interval, Zielwert; // Tageszeit überprüfen on({id: "javascript.0.Astro.Tageszeit.current", change: "any"}, function (obj) { var value = obj.state.val; var oldValue = obj.oldState.val; //Morgendämmerung if (getState("javascript.0.Astro.Tageszeit.current").val == 'Morgendämmerung') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.12 - dawn").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.11 - nauticalDawn").val); return v.getHours() * 60 + v.getMinutes();})(); // nächste Astrozeit minus aktuellen Astrozeit in min i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val) / Hilfswert_Zeiten)*10)/10; // i = Die Höhe der Schritte um die Kelvinzahl anzupassen setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung").val); //Startwert für Hilfswert_Kelvin Z_C3_A4hler_Schleife = 0; startInt (); Zielwert = getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val; } //Sonnenaufgang else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Sonnenaufgang') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.03 - goldenHourEnd").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.12 - dawn").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val); Z_C3_A4hler_Schleife = 0; startInt (); Zielwert = getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val; console.log("Startwert: " + getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang").val); console.log("Zielwert: " + Zielwert); } //Vormittag else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Vormittag') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.04 - solarNoon").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.03 - goldenHourEnd").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val); Z_C3_A4hler_Schleife = 0; startInt (); Zielwert = getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val; console.log("Startwert: " + getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag").val); console.log("Zielwert: " + Zielwert); } //Mittag else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Mittag') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.05 - goldenHour").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.04 - solarNoon").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.floor (((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val) / Hilfswert_Zeiten)); setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val); Z_C3_A4hler_Schleife = 0; startInt (); Zielwert = getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val; console.log("Startwert: " + getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag").val); console.log("Zielwert: " + Zielwert); } //Abend else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abend') { Hilfswert_Zeiten = (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.09 - nauticalDusk").val); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.05 - goldenHour").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val); Z_C3_A4hler_Schleife = 0; startInt (); Zielwert = getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val; console.log("Startwert: " + getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend").val); console.log("Zielwert: " + Zielwert); } //Abenddämmerung else if (getState("javascript.0.Astro.Tageszeit.current").val == 'Abenddämmerung') { Hilfswert_Zeiten = (function () {var v = getDateObject('21:00'); return v.getHours() * 60 + v.getMinutes();})() - (function () {var v = getDateObject(getState("javascript.0.Astro.Zeiten.09 - nauticalDusk").val); return v.getHours() * 60 + v.getMinutes();})(); i = Math.round(((getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht").val - getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val) / Hilfswert_Zeiten)*10)/10; setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val); Z_C3_A4hler_Schleife = 0; startInt (); Zielwert = getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht").val; console.log("Startwert: " + getState("javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung").val); console.log("Zielwert: " + Zielwert); } console.log("Schleifennummer: " + Z_C3_A4hler_Schleife); console.log("Kelvin Werterhöhung: " + i); console.log("Anzahl der Schleifen: " + Hilfswert_Zeiten); }); startInt = function() { Interval = setInterval(function() { setState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin", Math.round(getState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin").val + i)); // Hilfswert Kelvin ist ein Datenpunkt für die Übergabe an die Leuchten Z_C3_A4hler_Schleife = Z_C3_A4hler_Schleife+1; console.log("Schleifennummer: " + Z_C3_A4hler_Schleife); console.log("Hilfswert_Kelvin: " + getState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin").val); if (Z_C3_A4hler_Schleife >= Hilfswert_Zeiten || getState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin").val == Zielwert) { clearInterval (Interval); Z_C3_A4hler_Schleife = 0; return } }, 60000); };
-
@lalalalala
Vielen Dank. Werde ich die Tage mal testen. Ziehe gerade mit meinem ioBroker auf ein anderes System. Könnte also ein bisschen dauern bis ich mich wieder Melde. -
ich weiß nicht wie weit du bist.
Ich selbst hab nochmal kleine Änderungen vorgenommen.
Das Skript läuft dabei jedes Mal zwei oder drei Tage lang gut und dann fängt es an sich aufzuhängen. Nach Neustart funktioniert wieder alles.
Leider hab ich noch nicht herausgefunden woran es liegt. Vermute mal an der Schleife im letzten Teil des Skripts.Vielleicht gibt es ja noch eine weitere Person, die hier helfen kann. Jemand der sich besser mit Programmieren auskennt oder vielleicht auch eine ähnliche Herausforderung hatte.
-
@lalalalala
Habe dein Skript am laufen. Bisher läuft es auch gut. Man sieht ja immer schön im Log das es läuft und wie die Werte gerade sind. Allerdings kann ich zum "aufhängen" noch nichts sagen. Bin gerade mit ioBroker umgezogen und habe den ab und zu neu gestartet. Kann aber mal drauf achten wenn der paar Tage durch läuft ob das Skript dann noch funktioniert. -
@lalalalala
Hab das Skript jetzt mal ein paar Tage laufen lassen.
Die Schleiße hört leider nicht auf und fängt wieder von vorne an. Wenn dann lange keine "neue" Berechnung gemacht werden muss, also z.B. nachts, läuft die Schleiße immer wieder von vorne durch und der Kelvinwert sinkt immer weiter. War nachts schon bei -4200 Kelvin.
Klappt leider noch nicht so ganz. Schade das ich kein JS kann. -
Danke für ein Feedback.
Habe mir Hilfe geholt und das Skript komplett überarbeitet.var INTERVAL_MS = 1000 * 60 var ASTRO_DAYTIME = "javascript.0.Astro.Tageszeit.current"; var DYNAMIC_LIGHT = "javascript.0.Dynamisches_Licht.Hilfswert_Kelvin"; var KELVIN_DAYBREAK = "javascript.0.Dynamisches_Licht.Kelvin_Werte.Morgendämmerung"; var KELVIN_SUNRISE = "javascript.0.Dynamisches_Licht.Kelvin_Werte.Sonnenaufgang"; var KELVIN_FORENOON = "javascript.0.Dynamisches_Licht.Kelvin_Werte.Vormittag"; var KELVIN_NOON = "javascript.0.Dynamisches_Licht.Kelvin_Werte.Mittag"; var KELVIN_TWILIGHT = "javascript.0.Dynamisches_Licht.Kelvin_Werte.Abendämmerung"; var KELVIN_EVE = "javascript.0.Dynamisches_Licht.Kelvin_Werte.Abend"; var KELVIN_NIGHT = "javascript.0.Dynamisches_Licht.Kelvin_Werte.Nacht"; var interval /** * @param step Die Höhe der Schritte um die Kelvinzahl anzupassen * @param runs Anzahl der Durchläufe */ function startDimmer (step, runs) { if (interval) { clearInterval(interval); } //Startwert setzen für Hilfswert_Kelvin setStartKelvinState(); var counter = 0 interval = setInterval(function() { var kelvin = getKelvinState() setKelvin(Math.round(kelvin + step)); // Hilfswert Kelvin ist ein Datenpunkt für die Übergabe an die Leuchten counter = counter + 1; if (counter >= runs) { console.log("Ende dimmer"); clearInterval(interval); return } }, INTERVAL_MS); console.log("Start dimmer"); } /** HELPER FUNCTIONS **/ function getMinutes (time) { var dateString = time.indexOf("javascript") >= 0 ? getState(time).val : time; var v = getDateObject(dateString); return v.getHours() * 60 + v.getMinutes(); } function getTimeDifference (time1, time2) { return getMinutes(time1) - getMinutes(time2) } function getTimeStep (time1, time2, runs) { return Math.round(((getState(time1).val - getState(time2).val) / runs) * 10) / 10; } function getKelvinState () { return getState(DYNAMIC_LIGHT).val; } function setKelvin (value) { return setState(DYNAMIC_LIGHT, value); } function setKelvinState (state) { setKelvin(getState(state).val); } function setStartKelvinState () { var state switch (getState(ASTRO_DAYTIME).val) { case 'Morgendämmerung': state = KELVIN_DAYBREAK; break; case 'Sonnenaufgang': state = KELVIN_SUNRISE; break; case 'Vormittag': state = KELVIN_FORENOON; break; case 'Mittag': state = KELVIN_NOON; break; case 'Abend': state = KELVIN_EVE; break; case 'Nacht': state = KELVIN_NIGHT; break; case 'Abenddämmerung': state = KELVIN_TWILIGHT; break; } if (state) { setKelvinState(state); } } function proveDaytime (obj) { var runs, step; console.log('ASTRO_DAYTIME: ' + obj.state.val) switch (obj.state.val) { case 'Morgendämmerung': runs = getTimeDifference("javascript.0.Astro.Zeiten.12 - dawn", "javascript.0.Astro.Zeiten.11 - nauticalDawn"); step = getTimeStep(KELVIN_SUNRISE, KELVIN_DAYBREAK, runs); setKelvinState(KELVIN_DAYBREAK); break; case 'Sonnenaufgang': runs = getTimeDifference("javascript.0.Astro.Zeiten.03 - goldenHourEnd", "javascript.0.Astro.Zeiten.12 - dawn"); step = getTimeStep(KELVIN_FORENOON, KELVIN_SUNRISE, runs); setKelvinState(KELVIN_SUNRISE); break; case 'Vormittag': runs = getTimeDifference("javascript.0.Astro.Zeiten.04 - solarNoon", "javascript.0.Astro.Zeiten.03 - goldenHourEnd"); step = getTimeStep(KELVIN_NOON, KELVIN_FORENOON, runs); setKelvinState(KELVIN_FORENOON); break; case 'Mittag': runs = getTimeDifference("javascript.0.Astro.Zeiten.05 - goldenHour", "javascript.0.Astro.Zeiten.04 - solarNoon"); step = getTimeStep(KELVIN_EVE, KELVIN_NOON, runs); setKelvinState(KELVIN_NOON); break; case 'Abend': runs = getTimeDifference("javascript.0.Astro.Zeiten.09 - nauticalDusk", "javascript.0.Astro.Zeiten.05 - goldenHour"); step = getTimeStep(KELVIN_TWILIGHT, KELVIN_EVE, runs); setKelvinState(KELVIN_EVE); break; case 'Abenddämmerung': runs = getTimeDifference("21:00", "javascript.0.Astro.Zeiten.09 - nauticalDusk"); step = getTimeStep(KELVIN_NIGHT, KELVIN_TWILIGHT, runs); setKelvinState(KELVIN_TWILIGHT); break; default: console.log('State missing: ' + obj.state.val) break; } if (step && runs) { startDimmer(step, runs); } } /** ADD STATES **/ /***/ createState(KELVIN_DAYBREAK, { name: 'Morgendämmerung', unit: 'K', type: 'number', def: 2700, }); createState(KELVIN_SUNRISE, { name: 'Sonnenaufgang', unit: 'K', type: 'number', def: 4000, }); createState(KELVIN_FORENOON, { name: 'Vormittag', unit: 'K', type: 'number', def: 5500, }); createState(KELVIN_NOON, { name: 'Mittag', unit: 'K', type: 'number', def: 5000, }); createState(KELVIN_EVE, { name: 'Abend', unit: 'K', type: 'number', def: 4500, }); createState(KELVIN_TWILIGHT, { name: 'Abenddämmerung', unit: 'K', type: 'number', def: 3000, }); createState(KELVIN_NIGHT, { name: 'Nacht', unit: 'K', type: 'number', def: 2100, }); createState(DYNAMIC_LIGHT, { name: 'Hilfswert_Kelvin', unit: 'K', type: 'number', def: 5000, }); /***/ // Tageszeit überprüfen on({ id: ASTRO_DAYTIME, change: "any" }, proveDaytime);