NEWS
Interaktionen zwischen Skripten
-
Hallo zusammen,
mir ist heute ein ungewolltes Interagieren von zwei Skripten aufgefallen (zumindest ist das bisher meine einzige Vermutung).
Ich habe in einem Zimmer mehrere Lampen, welche ich mittels Skript zusammen mit einem Unterputz-Dimmer steuere.
Vgl:
on({id:"hm-rpc.0.JEQ0vvv1.LEVEL_REAL"/*Unterputzdimmer*/, change:"ne"},Licht_an); function Licht_an(){ var level = getState("hm-rpc.0.JEQ0208109.1.LEVEL_REAL").val; if(isAstroDay()){ setState("hm-rpc.0.JEQ0yyy.1.LEVEL",level); }else{ setStateDelayed("hm-rpc.0.JEQ0xxx.1.LEVEL",level,300,false); setStateDelayed("hm-rpc.0.JEQ0yyy.1.LEVEL",level,300,false); if(level >= 90){ setStateDelayed("hm-rpc.0.KEQ0xy.1.STATE",true, 300, false); }else{ setStateDelayed("hm-rpc.0.KEQ0xy.1.STATE",false,300, false); } }
Das Skript setzt in Abhängigkeit des REAL_LEVEL-Werts die Werte der drei anderen Lampen. Dies funktioniert über den Taster des Dimmaktors völlig problemlos und zuverlässig. Es kommt zu keinerlei "Schwankungen" oder "Pendelungen" beim schalten.
Parallel nutze ich das Licht_aus Skript hier aus dem Forum:
var idx = 0; var interval = 500; $('channel[state.id=*.STATE](functions=Licht)').each(function(id,i) { if (getState(id).val) setStateDelayed(id, false, (idx++) * interval); }); $('channel[state.id=*.LEVEL](functions=Licht)').each(function(id,i) { if (getState(id).val > 0) setStateDelayed(id, 0, (idx++) * interval); }); setTimeout(function () { setState(idTrigger, false, true); }, 2000); log('Alle Schalter und Dimmer im Erdgeschoss abgeschaltet');
Dieses schaltet genau wie es soll alle Lampen im Gewerk Licht aus. Jedoch kommt es zwischen den beiden Skripten zu Interaktionen.
Die vier per Skript "verschalteten" Lampen gehen beim auslösen des Licht_aus Skripts abwechselt an und aus. Irgendwann "beruhigt" sich das Ganze und geht auch aus. Aber ich verstehe nicht ganz, wo das Problem liegt.
Wahrscheinlich müsste ich im ersten Skript eine andere Umsetzung wählen… Ich bin etwas ratlos und für Tipps dankbar!
Viele Grüße
Trident
-
Morjens,
die Scripte arbeiten schon so wie sie sollen. Während der Dimmer einen Wert anfährt, ändert sich der Dimmwert. Darauf reagiert dein 1. Script halt auch beim Ausschalten.
Änder mal den Trigger auf den bestätigten Wert, dann sollte das 1. Script erst laufen wenn der Endwert erreicht ist:
on({id:"hm-rpc.0.JEQ0vvv1.LEVEL_REAL"/Unterputzdimmer/, ack: true},Licht_an);
Grüße
Brati
-
Hi,
danke für den Tipp, klappt super!
Viele Grüße
Trident