NEWS
Frage zum setTimout-Trigger
-
Hallo,
ich nutze folgendes Skript, um nach einer voreingestellten Zeit wieder zu bestimmten Views meiner vis-Anzeige zurück zu kehren.
on("vis.0.control.data", function(obj){ if((obj.state.val === "XGA/02DG") || (obj.state.val === "XGA/03OG") || (obj.state.val === "XGA/04EG") || (obj.state.val === "XGA/05UG") || (obj.state.val === "XGA/06Heizung") || (obj.state.val === "XGA/07Wetter")){ setTimeout(function(){ setState("vis.0.control.command", '{"instance": "*", "data": "01Haus", "command": "changeView"}'); }, 5 * 60000); // autoamtische Rückkehr auf Homeview nach 5 Minuten } if(obj.state.val === "XGA/08CCU"){ if(getState("hm-rega.0.maintenance").val !== 0){ setTimeout(function(){ setState("vis.0.control.command", '{"instance": "*", "data": "01Haus", "command": "changeView"}'); }, 3 * 60000); // autoamtische Rückkehr auf Homeview nach 3 Minuten } else{ setTimeout(function(){ setState("vis.0.control.command", '{"instance": "*", "data": "01Haus", "command": "changeView"}'); }, 30 * 1000); // autoamtische Rückkehr auf Homeview nach 30 Sekunden } } if(obj.state.val === "XGA/10HeizungTimer"){ setTimeout(function(){ setState("vis.0.control.command", '{"instance": "*", "data": "06Heizung", "command": "changeView"}'); }, 3 * 60000); // autoamtische Rückkehr auf Heizungsview nach 3 Minuten } });
Irgendwie scheint es aber so zu sein, dass setTimeout nicht neu getriggert wird, wenn zwischendurch eine der Bedinungen wieder erfüllt wird. Sprich, der Timer zählt einfach weiter, bis er auf Null ist, egal, was zwischendurch passiert. Bei den HomeMatic-Timern ist das z.B. nicht so. Diese werden bei jedem Ereignis wieder neu getriggert.
Wie kann ich das gewünschte Verhalten erzielen?
Gruß,
Thorsten
-
@dtp:Wie kann ich das gewünschte Verhalten erzielen? `
Mit Timer-Variablen, die gelöscht werden.var timer1 = null; vat timer2 = null; var timer3 = null; on(... ... if(timer1) clearTimeout(timer1); timer1 = setTimeout(function(){ ... if(timer2) clearTimeout(timer2); timer2 = setTimeout(function(){ ... usw. });
-
Danke für die schnelle Antwort. Werde ich mal ausprobieren.
Gruß,
Thorsten