Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Alle Lichter über vis hqwidgets aus- und einschalten

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    16
    1
    1.9k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    912

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

Alle Lichter über vis hqwidgets aus- und einschalten

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
2 Beiträge 2 Kommentatoren 1.0k Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • ScroungerS Offline
    ScroungerS Offline
    Scrounger
    Developer
    schrieb am zuletzt editiert von
    #1

    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".
    4571_objekt.png

    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.
     ![4571_widget_settings.png](/assets/uploads/files/4571_widget_settings.png) 
    
    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]
    
    1 Antwort Letzte Antwort
    0
    • arteckA Offline
      arteckA Offline
      arteck
      Developer Most Active
      schrieb am zuletzt editiert von
      #2

      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]
      

      zigbee hab ich, zwave auch, nuc's genauso und HA auch

      1 Antwort Letzte Antwort
      0
      Antworten
      • In einem neuen Thema antworten
      Anmelden zum Antworten
      • Älteste zuerst
      • Neuste zuerst
      • Meiste Stimmen


      Support us

      ioBroker
      Community Adapters
      Donate

      646

      Online

      32.6k

      Benutzer

      82.2k

      Themen

      1.3m

      Beiträge
      Community
      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
      ioBroker Community 2014-2025
      logo
      • Anmelden

      • Du hast noch kein Konto? Registrieren

      • Anmelden oder registrieren, um zu suchen
      • Erster Beitrag
        Letzter Beitrag
      0
      • Home
      • Aktuell
      • Tags
      • Ungelesen 0
      • Kategorien
      • Unreplied
      • Beliebt
      • GitHub
      • Docu
      • Hilfe