NEWS
Alle Lichter über vis hqwidgets aus- und einschalten
-
Hallo zusammen,
versuche gerade über den bool.button des hqwidgets die Funktion zu realisieren alle meine Lichter in der Wohnung auszuschalten, evtl. auch anzuschalten.
Hab mir dazu zunächst ein Objekt erstellt "anyLightsOn".

Das Objekt wird mit folgender Funktion (Status on/off aller Lampen abfragen) auf true bzw. false gesetzt:
`// Status aller Lichter in der Wohnung erfassen und in Variable speichern // Ids aller Lichter in der Wohnung var liste = ["hm-rpc.0.id.1.STATE"/*Speisekammer Schalter.STATE*/, "hm-rpc.0.id.1.STATE"/*Küche Schalter.STATE*/, "hm-rpc.0.id.1.STATE"/*WC Schalter.STATE*/, "hm-rpc.0.id.1.STATE"/*Bad Schalter.STATE*/, "hm-rpc.0.id.1.STATE"/*Dusche Schalter.STATE*/, "hm-rpc.0.id.1.LEVEL"/*Schlafzimmer 1 Dimmer.LEVEL*/, "hm-rpc.0.id.1.LEVEL"/*Schlafzimmer 2 Dimmer.LEVEL*/, "hm-rpc.0.id.1.LEVEL"/*Wohnzimmer 1 Dimmer.LEVEL*/, "hm-rpc.0.id.1.LEVEL"/*Wohnzimmer 2 Dimmer.LEVEL*/, "hm-rpc.0.id.1.LEVEL"/*Esszimmer 1 Dimmer.LEVEL*/, "hm-rpc.0.id.1.LEVEL"/*Esszimmer 2 Dimmer.LEVEL*/, "hm-rpc.0.id.1.STATE"/*Flur 1 Schalter.STATE*/, "hm-rpc.0.id.1.STATE"/*Flur 2 Schalter.STATE*/]; //Listener für alle Lichter bei Veränderung on({id: liste}, function(){ var anyLightsOn = false; for (var i=0; i <liste.length; i++)/{/prüfen/ob/noch/ein/licht/in/der/wohnung/an/ist/if/(liste[i].includes("level"))/dimmer/state/auslesen/(getstate(liste[i]).val="">0) { anyLightsOn = true; } } else { // Schalter state auslesen if (getState(liste[i]).val === true){ anyLightsOn = true; } } } setState("vars.0.wohnung.anyLightsOn"/*wohnung.anyLightOn*/, anyLightsOn); console.log("any lights in wohnung on: " + anyLightsOn); });</liste.length;>` Das Objekt "anyLightsOn" habe ich dem widget als Schalter zugeordnet: Je nach dem ob ein Licht in der Wohnung an ist oder auch nicht, wird mir über das Widget der Status richtig ausgeben, das klappt soweit schon mal.  Ich möchte jetzt gerne aber noch über das Widget manuel (also per klick) mindestens alle Lichter ausschalten, super wäre natürlich auch wenn man sie einschalten könnte. Habe das versucht, in dem ich einen Listener / Trigger auf das Objekt "anyLightsOn" setze und sobald dieser auf false ist, werden aller Lichter ausgeschaltet: `~~[code]~~//Listener für Var 'vars.0.wohnung.anyLightsOn' wenn auf false gesetzt wird // on({id: "vars.0.wohnung.anyLightsOn"}, // function(obj){ // nur ausführen wenn auf false // if (obj.state.val === false){ // for (var i=0; i<liste.length; i++)/{/alle/lichter/ausschalten/if/(liste[i].includes("level"))/dimmer/setstate(liste[i],/0);/}/else/schalter/false);/});<e=""></liste.length;>` Probelm ist jetzt, das sich daraus verständlicherweise eine Dauerschleife ergibt. Hab schon viel gesucht, aber leider keinen brauchbaren Lösungsansatz gefunden, bzw. verstanden ;) Hoffe Ihr könnt mir weiterhelfen?[/i][/i][/i][/code][/i][/i][/i] -
reagier doch nur wenn vars.0.wohnung.anyLightsOn false ist
`on({id: 'vars.0.wohnung.anyLightsOn', change: 'ne', val: false}, function() { // nur ausführen wenn auf false for (var i=0; i<liste.length; i++)/{/alle/lichter/ausschalten/if/(liste[i].includes("level"))/dimmer/setstate(liste[i],/0);/}/else/schalter/false);/});<e=""></liste.length;>`[/i][/i][/i]
Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.
Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.
Mit deinem Input könnte dieser Beitrag noch besser werden 💗
Registrieren Anmelden