Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Tim Leuschner

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Profile
    • Following 0
    • Followers 0
    • Topics 1
    • Posts 7
    • Best 0
    • Groups 1

    Tim Leuschner

    @Tim Leuschner

    Starter

    0
    Reputation
    20
    Profile views
    7
    Posts
    0
    Followers
    0
    Following
    Joined Last Online

    Tim Leuschner Follow
    Starter

    Latest posts made by Tim Leuschner

    • RE: [Vorlage]Wechselschaltung mit Javascript

      Nach einigen Änderungen nun umgestellt auf eine Javascript-Klasse, dadurch deutlich leichter zu verwenden und als Vorlage tauglich:

      Script für Wechselschaltung mit beliebig vielen Schaltern, Tastern, & Aktoren:

      //  Ich benutze virtuelle Schalter (Datenpunkte) um z.B. VIS-Seiten aufzubauen, weil ich so 
      //  bei einem Austausch physischer Komponenten (Anderer Hersteller/Name etc.) nicht die 
      //  VIS-Visualisierung und Scripte anpassen muß 
      // 
      //  Die sonoff-Touch-Schalter schalten die LED's der Touch-Schaltflächen ein, wenn das zugehörige  Relais an ist.
      //  Ich invertiere den Schaltzustand der sonoff-Touch-Schalter, damit die LED der jew. Touch-Schaltfläche
      //  leuchtet, wenn die zu schaltende Lampe aus ist (so findet man sie im Dunkeln).
      
      // Abspeichern der Javascript-Instanz in Konstante, um in den 
      // Event-Scubscriptions zu prüfen, woher der Aufruf kommt und 
      // so Ping/Pong zu vermeiden ( CreditsTo: @paul53 ) 
      const js = 'system.adapter.javascript.' + instance;
      
      
      
      class VirtualMultiSwitch {
         constructor (idVirtualSwitch='',msDelay=100) {
             this.aPowr = new Array();     // zu schaltende Aktoren
             this.aNorm = new Array();     // normale Schalter
             this.aInvt = new Array();     // zu invertierende Schalter
             this.aBttn = new Array();     // auslösende Tatser
             this.VirtS = idVirtualSwitch; 
             this.Counter = 0;
             this.Delay = msDelay;
         }  
         incS()    { this.Counter +=1; }
         decS()    { this.Counter -=1; }
         addP(Name){ this.aPowr = this.aPowr.concat(Name); }
         addN(Name){ this.aNorm = this.aNorm.concat(Name); }
         addI(Name){ this.aInvt = this.aInvt.concat(Name); }
         addB(Name){ this.aBttn = this.aBttn.concat(Name); }
         doSwitchPhysical(obj){  
             if (this.Counter <= 1){
                 this.Counter +=1;
                 setState(this.VirtS,(this.aBttn.indexOf(obj.id  )>=0 ? !getState(this.VirtS).val : this.aNorm.indexOf(obj.id)>=0 ? obj.state.val : !obj.state.val));
                 setTimeout(()=>this.decS(), this.Delay); 
             }
         }
         doSwitchVirtual(obj){  
             if (this.Counter <= 1){
                 this.Counter +=1;
                 this.aNorm.forEach(function (TargetId,idx) {setState(TargetId,  obj.state.val);}); 
                 this.aInvt.forEach(function (TargetId,idx) {setState(TargetId, !obj.state.val);}); 
                 this.aPowr.forEach(function (TargetId,idx) {setState(TargetId,  obj.state.val);}); 
                 setTimeout(()=>this.decS(), this.Delay); 
             }
         }
         Start() {
             on ({id:this.aNorm, change:"ne", ack: true , fromNe: js}, (obj) =>this.doSwitchPhysical(obj));
             on ({id:this.aInvt, change:"ne", ack: true , fromNe: js}, (obj) =>this.doSwitchPhysical(obj));
             on ({id:this.aBttn, change:"ne", ack: true , fromNe: js}, (obj) =>this.doSwitchPhysical(obj));
             on ({id:this.VirtS, change:"ne"                        }, (obj) =>this.doSwitchVirtual(obj));  
         }
         Stop() {
             unsubscribe(this.aNorm);
             unsubscribe(this.aInvt);
             unsubscribe(this.aBttn);
             unsubscribe(this.VirtS);  
         }
      }
      
      //  WechselSchalter01:
      var WS01 = new VirtualMultiSwitch('javascript.0.virtualDevice.Schalter.Eins.POWER');
          WS01.addP('sonoff.0.Shelly01.Switch.Power'   ); // z.B. ein Shelly 1, der die eigentliche Lampe schaltet
                                                             
          WS01.addN('hm-rega.0.1111'                   ); // HomeMatic, realisiert mit CCU-Systemvariable, 
                                                          // die in CCU durch Funkschalter getoggelt wird
                                                          // und in ioBroker als "hmRega.0.XYZ" auftaucht
                                                                 
          WS01.addI('sonoff.0.T1_Touch_01.POWER1'      ); // die zu invertierenden Schalter hinzufügen
         
          WS01.addB('hm-rpc.0.ABCDEFGH.1.PRESS_SHORT'  ); // ein Hommatic-Funkstaster 
          WS01.Start();
      
      
      //  WechselSchalter02 (ohne Kommentare viel kürzer)
      var WS02 = new VirtualMultiSwitch('javascript.0.virtualDevice.Schalter.Zwei.POWER');
          WS02.addP('sonoff.0.Lampe02.POWER'           );
          WS02.addN('hm-rega.0.2222'                   );
          WS02.addI('sonoff.0.T1_Touch_03.POWER2'      );  
          WS02.Start();
      
      
      //  WechselSchalter03 - schaltet eine ganze Reihe von Aktoren (=Szene)
      var WS03 = new VirtualMultiSwitch('javascript.0.virtualDevice.Schalter.Drei.POWER');
          WS03.addP('sonoff.0.S4Pro_01.POWER1'         );
          WS03.addP('sonoff.0.S4Pro_01.POWER2'         );
          WS03.addP('sonoff.0.S4Pro_01.POWER3'         );
          WS03.addP('sonoff.0.S4Pro_02.POWER1'         );
          WS03.addP('sonoff.0.XYZ.POWER'               );
          WS03.addP('javascript.0.virtualDevice.Schalter.Eins.POWER'); // ja, auch der 1. Virtuelle Schalter wird mitgeschaltet
       
          WS03.addN('hm-rega.0.3333'                   ); // dafür nur ein auslösender Schalter ...
          WS03.Start();
      
      

      Danke allen Inspirateuren ( insbesondere @Asgothian & @paul53 )!

      posted in JavaScript
      Tim Leuschner
      Tim Leuschner
    • RE: [Vorlage]Wechselschaltung mit Javascript

      @paul53: hatte ich natürlich nicht (Depp). damit geht es!
      @Asgothian : setTimer funktioniert, wenn ich den TimeOut-Wert entsprechend hoch stelle (1000ms).

      @All: mir ist noch immer nicht klar, warum mein Singleton-Ansatz (setzen eines Datenpunktes, solange die Schalterei dauert - sollte nichts anderes sein, als Asgothian's Abfrage, ob timout != null ist) und die unsubscribe-Variante nicht funktioniert hat.

      posted in JavaScript
      Tim Leuschner
      Tim Leuschner
    • RE: [Vorlage]Wechselschaltung mit Javascript

      @paul53 :

      fromNe: js
      

      führt bei mir zu Compilier-fehler,

      fromNe: "js"
      

      wirkt nicht.
      Ausserdem ist es schon ein bisschen komplexer, da 8 Schalter und 3 Taster zusammengeführt werden müssen (wobei einige Schalter invertiert werden müssen (sonoff Touch), damit die LED's im Aus- und nicht im Eingeschalteten Zustand leuchten), was mit dem

      setState(AndereID, obj.state.val);
      

      nicht so elegant erscheint.

      posted in JavaScript
      Tim Leuschner
      Tim Leuschner
    • RE: [Vorlage]Wechselschaltung mit Javascript

      @Asgothian: könntest Du ein code-Beispiel für "Geschützt durch einen Timer" posten?

      posted in JavaScript
      Tim Leuschner
      Tim Leuschner
    • RE: [Vorlage]Wechselschaltung mit Javascript

      @paul53 Schalter (sonoff Touch), die HM's sind Taster und müssen nicht aktualisiert werden

      posted in JavaScript
      Tim Leuschner
      Tim Leuschner
    • RE: [Vorlage]Wechselschaltung mit Javascript

      Es geht darum, mehrere Schalter (sonoff Touch T1/T2/T3, HomeMatic-Funk und VirtuellerSchalter(Datenpunkt für Darstellung in Vis) als Trigger für das Schalten eines Aktors (shelly 1) an dem der Verbraucher hängt zu benutzen .

      Dabei soll das Schalten eines beliebigen Schalters alle anderen in den Zustand des auslösenden Schalters bringen (damit z.B. die LED's and den Touch's entsprechend leuchten oder nicht und die Darstellung in Vis aktuell ist).

      @Asgothian: Daher reicht ein Toggle nicht.

      posted in JavaScript
      Tim Leuschner
      Tim Leuschner
    • [Vorlage]Wechselschaltung mit Javascript

      Nach einigen Änderungen nun umgestellt auf eine Javascript-Klasse, dadurch deutlich leichter zu verwenden und als Vorlage tauglich:

      Script für Wechselschaltung mit beliebig vielen Schaltern, Tastern, & Aktoren:

      //  Ich benutze virtuelle Schalter (Datenpunkte) um z.B. VIS-Seiten aufzubauen, weil ich so 
      //  bei einem Austausch physischer Komponenten (Anderer Hersteller/Name etc.) nicht die 
      //  VIS-Visualisierung und Scripte anpassen muß 
      // 
      //  Die sonoff-Touch-Schalter schalten die LED's der Touch-Schaltflächen ein, wenn das zugehörige  Relais an ist.
      //  Ich invertiere den Schaltzustand der sonoff-Touch-Schalter, damit die LED der jew. Touch-Schaltfläche
      //  leuchtet, wenn die zu schaltende Lampe aus ist (so findet man sie im Dunkeln).
      
      // Abspeichern der Javascript-Instanz in Konstante, um in den 
      // Event-Scubscriptions zu prüfen, woher der Aufruf kommt und 
      // so Ping/Pong zu vermeiden ( CreditsTo: @paul53 ) 
      const js = 'system.adapter.javascript.' + instance;
      
      
      
      class VirtualMultiSwitch {
         constructor (idVirtualSwitch='',msDelay=100) {
             this.aPowr = new Array();     // zu schaltende Aktoren
             this.aNorm = new Array();     // normale Schalter
             this.aInvt = new Array();     // zu invertierende Schalter
             this.aBttn = new Array();     // auslösende Tatser
             this.VirtS = idVirtualSwitch; 
             this.Counter = 0;
             this.Delay = msDelay;
         }  
         incS()    { this.Counter +=1; }
         decS()    { this.Counter -=1; }
         addP(Name){ this.aPowr = this.aPowr.concat(Name); }
         addN(Name){ this.aNorm = this.aNorm.concat(Name); }
         addI(Name){ this.aInvt = this.aInvt.concat(Name); }
         addB(Name){ this.aBttn = this.aBttn.concat(Name); }
         doSwitchPhysical(obj){  
             if (this.Counter <= 1){
                 this.Counter +=1;
                 setState(this.VirtS,(this.aBttn.indexOf(obj.id  )>=0 ? !getState(this.VirtS).val : this.aNorm.indexOf(obj.id)>=0 ? obj.state.val : !obj.state.val));
                 setTimeout(()=>this.decS(), this.Delay); 
             }
         }
         doSwitchVirtual(obj){  
             if (this.Counter <= 1){
                 this.Counter +=1;
                 this.aNorm.forEach(function (TargetId,idx) {setState(TargetId,  obj.state.val);}); 
                 this.aInvt.forEach(function (TargetId,idx) {setState(TargetId, !obj.state.val);}); 
                 this.aPowr.forEach(function (TargetId,idx) {setState(TargetId,  obj.state.val);}); 
                 setTimeout(()=>this.decS(), this.Delay); 
             }
         }
         Start() {
             on ({id:this.aNorm, change:"ne", ack: true , fromNe: js}, (obj) =>this.doSwitchPhysical(obj));
             on ({id:this.aInvt, change:"ne", ack: true , fromNe: js}, (obj) =>this.doSwitchPhysical(obj));
             on ({id:this.aBttn, change:"ne", ack: true , fromNe: js}, (obj) =>this.doSwitchPhysical(obj));
             on ({id:this.VirtS, change:"ne"                        }, (obj) =>this.doSwitchVirtual(obj));  
         }
         Stop() {
             unsubscribe(this.aNorm);
             unsubscribe(this.aInvt);
             unsubscribe(this.aBttn);
             unsubscribe(this.VirtS);  
         }
      }
      
      //  WechselSchalter01:
      var WS01 = new VirtualMultiSwitch('javascript.0.virtualDevice.Schalter.Eins.POWER');
          WS01.addP('sonoff.0.Shelly01.Switch.Power'   ); // z.B. ein Shelly 1, der die eigentliche Lampe schaltet
                                                             
          WS01.addN('hm-rega.0.1111'                   ); // HomeMatic, realisiert mit CCU-Systemvariable, 
                                                          // die in CCU durch Funkschalter getoggelt wird
                                                          // und in ioBroker als "hmRega.0.XYZ" auftaucht
                                                                 
          WS01.addI('sonoff.0.T1_Touch_01.POWER1'      ); // die zu invertierenden Schalter hinzufügen
         
          WS01.addB('hm-rpc.0.ABCDEFGH.1.PRESS_SHORT'  ); // ein Hommatic-Funkstaster 
          WS01.Start();
      
      
      //  WechselSchalter02 (ohne Kommentare viel kürzer)
      var WS02 = new VirtualMultiSwitch('javascript.0.virtualDevice.Schalter.Zwei.POWER');
          WS02.addP('sonoff.0.Lampe02.POWER'           );
          WS02.addN('hm-rega.0.2222'                   );
          WS02.addI('sonoff.0.T1_Touch_03.POWER2'      );  
          WS02.Start();
      
      
      //  WechselSchalter03 - schaltet eine ganze Reihe von Aktoren (=Szene)
      var WS03 = new VirtualMultiSwitch('javascript.0.virtualDevice.Schalter.Drei.POWER');
          WS03.addP('sonoff.0.S4Pro_01.POWER1'         );
          WS03.addP('sonoff.0.S4Pro_01.POWER2'         );
          WS03.addP('sonoff.0.S4Pro_01.POWER3'         );
          WS03.addP('sonoff.0.S4Pro_02.POWER1'         );
          WS03.addP('sonoff.0.XYZ.POWER'               );
          WS03.addP('javascript.0.virtualDevice.Schalter.Eins.POWER'); // ja, auch der 1. Virtuelle Schalter wird mitgeschaltet
       
          WS03.addN('hm-rega.0.3333'                   ); // dafür nur ein auslösender Schalter ...
          WS03.Start();
      
      

      Danke allen Inspirateuren ( insbesondere @Asgothian & @paul53 )!
      Wer nachvollziehen möchte, wie ich zur Lösung gelangt bin, meine Ausgangsfrage und im Thread-Verlauf die Antworten...


      Moin Moin.
      Ich versuche eine virtuelle Wechselschaltung in Javascript zu realisieren.
      Ich lande immer wieder bei Endlos-Schleifen.
      Bisherige Ansätze:

      //Setzt Datenpunkt auf true und liefert true zurück, wenn Datenpunkt nicht schon auf true steht
      function enterSingleton(Singleton) {
        ReturnValue = false; 
        SingletonName = 'javascript.0.virtualDevice.Datenpunkte.Singletons.'+Singleton; 
        if (getState(SingletonName).val == false){
          setState(SingletonName,true);
          ReturnValue = true;
        }
        return ReturnValue;
      }
      // setzt Datenpunkt auf false
      function exitSingleton(Singleton) {
        SingletonName = 'javascript.0.virtualDevice.Datenpunkte.Singletons.'+Singleton; 
        setStateDelayed(SingletonName,false,300);
      }
      on({id:new RegExp('VurtuellerSchalter|PhysischerSchalter01|PhysischerSchalter02'), change: "ne"}, function (obj) {
        // Wenn Singleton nicht schon aktiv ist, Singleton aktivieren um erneute Ausführung zu verhindern und Befehle ausführen:
        if (enterSingleton('Wechselschaltung01')) { 
          setState('PhysischerSchalter01',obj.state.val);
          setState('PhysischerSchalter02',obj.state.val);
          setState ('VirtuellerSchalter',obj.state.val);
          //Singleton wieder freigeben
          exitSingleton('Wechselschaltung01');     
        }
      });
      


      // Funktion, die vom Eventhandler der physischen Schalter aufgerufen wird:
      function doHandlePhysisch(obj,Subscription){
        //physische Schalter von Eventsubscription trennen:
        unsubscribe(Subscription); 
        setState ('VirtuellerSchalter',obj.state.val);
       }
      on({id:'VirtuellerSchalter', change: "ne"},  function (obj) {
        //physische Schalter von Eventsubscription trennen
        unsubscribe(myPhysicalSubscription);
        setState('PhysischerSchalter01',obj.state.val);
        setState('PhysischerSchalter02',obj.state.val);
        // und wieder mit Eventsubscription verbinden:
        myPhysicalSubscription= on({id:new RegExp('PhysischerSchalter01|PhysischerSchalter02'), change: "ne"},  function (obj) {
          doHandlePhysisch(obj,myPhysicalSubscription);
        });
      });
      var myPhysicalSubscription= on({id:new RegExp('PhysischerSchalter01|PhysischerSchalter02'), change: "ne"},  function (obj) {
            doHandlePhysisch(obj,myPhysicalSubscription);
      });
      


      // tatsächliche EventHandler-Variable für die physischen Schalter,
      // schaltet den virtuellen Schalter:
      var MyHandler = function (obj){
          if (getState('VirtuellerSchalter').val != obj.state.val) {
              setState('VirtuellerSchalter',obj.state.val);
          }
      }
      //Dummy-Eventhandler-Variable:
      var MyDoNothing = function(obj){};
      //Variable für Eventhandlerfunktion: 
      var DoHandle = MyHandler; //Zeigt auf tats. Eventhandler
      //Subscriptions für die phys. Schalter
      on ({id:'PhysischerSchalter01',change:"any"},function(obj){
          DoHandle(obj);
      });
      on ({id:'PhysischerSchalter02',change:"any"},function(obj){
          DoHandle(obj);
      });
      // Subscription für den virtuellen Schalter:
      on ({id:'VirtuellerSchalter',change : "ne"},function (obj){
          DoHandle = MyDoNothing; // Eventhandler für die phys. Schalter zeigt auf Dummy
          setState('PhysischerSchalter01',obj.state.val);
          setState('PhysischerSchalter01',obj.state.val);
          DoHandle = MyHandler;     // Eventhandler für die phys. Schalter zeigt wieder auf tats. Funktion
      });
      


      Vorschläge sind höchst willkommen 😉
      ,

      posted in JavaScript
      Tim Leuschner
      Tim Leuschner
    Community
    Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
    The ioBroker Community 2014-2023
    logo