Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. [gelöst] Schaltzustand Verzögern

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] Schaltzustand Verzögern

    This topic has been deleted. Only users with topic management privileges can see it.
    • Aphofis
      Aphofis @paul53 last edited by

      @paul53

      Also so ???

      var timeout_aus, timeout_ein;
      
      
      on({id: 'sonoff.0.Aqua_Float.POWER4', val: true}, function (obj) {
        var value = obj.state.val;
        var oldValue = obj.oldState.val;
        if ((obj.state ? obj.state.val : "")) {
          timeout_aus = setTimeout(function () {
            setState("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, false);
            setState("javascript.0.scriptEnabled.Technik_Steuerung.Osmose_Niveau"/*scriptEnabled.Technik_Steuerung.Osmose_Niveau*/, false);
            setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
            sendTo("telegram.0", "send", {
                text: (['Filter Max erreicht, Skimmer & Osmose','\n','wurden abgeschaltet'].join(''))
            });
            console.log((['Filter Max erreicht, Skimmer & Osmose','\n','wurden abgeschaltet'].join('')));
          }, 5000);
          (function () {if (timeout_ein) {clearTimeout(timeout_ein); timeout_ein = null;}})();
        } else {
          timeout_ein = setTimeout(function () {
            setStateDelayed("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, true, 20000, true);
            setStateDelayed("javascript.0.scriptEnabled.Technik_Steuerung.Osmose_Niveau"/*scriptEnabled.Technik_Steuerung.Osmose_Niveau*/, true, 10000, false);
          }, 2000);
          (function () {if (timeout_aus) {clearTimeout(timeout_aus); timeout_aus = null;}})();
        }
      });
      on({id: 'sonoff.0.Aqua_Power.POWER3', change: "ne"}, function (obj) {
        var value = obj.state.val;
        var oldValue = obj.oldState.val;
        if (getState("sonoff.0.Aqua_Power.POWER3").val == true) {
          sendTo("telegram.0", "send", {
              text: (['Filter Max unterschritten, Skimmer & Osmose','\n','wurden wieder eingeschaltet'].join(''))
          });
          console.log((['Filter Max unterschritten, Skimmer & Osmose','\n','wurden wieder eingeschsaltet'].join('')));
        }
      });
      
      paul53 2 Replies Last reply Reply Quote 0
      • paul53
        paul53 @Aphofis last edited by

        @Aphofis sagte:

        Also so ???

        Ja, und das Ausschalten (sonst) könnte auch dort mitgeteilt werden.

        Aphofis 1 Reply Last reply Reply Quote 0
        • Aphofis
          Aphofis @paul53 last edited by

          @paul53
          Wie meinst du das ausschalten !?

          1 Reply Last reply Reply Quote 0
          • paul53
            paul53 @Aphofis last edited by

            @Aphofis
            Ich sehe gerade in Zeile 4, dass auf wahr getriggert wird. Das funktioniert nicht ! Triggere auf wurde geändert.

            1 Reply Last reply Reply Quote 0
            • Aphofis
              Aphofis last edited by

              Also beide Trigger auf wurde geändert !?

              paul53 1 Reply Last reply Reply Quote 0
              • paul53
                paul53 @Aphofis last edited by

                @Aphofis sagte:

                Also beide Trigger auf wurde geändert !?

                Ja.

                1 Reply Last reply Reply Quote 0
                • Aphofis
                  Aphofis last edited by

                  @paul53
                  So sollte es dann ja laufen.

                  var timeout_aus, timeout_ein;
                  
                  
                  on({id: 'sonoff.0.Aqua_Float.POWER4', change: "ne"}, function (obj) {
                    var value = obj.state.val;
                    var oldValue = obj.oldState.val;
                    if ((obj.state ? obj.state.val : "")) {
                      timeout_aus = setTimeout(function () {
                        setState("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, false);
                        setState("javascript.0.scriptEnabled.Technik_Steuerung.Osmose_Niveau"/*scriptEnabled.Technik_Steuerung.Osmose_Niveau*/, false);
                        setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                        sendTo("telegram.0", "send", {
                            text: (['Filter Max erreicht, Skimmer & Osmose','\n','wurden abgeschaltet'].join(''))
                        });
                        console.log((['Filter Max erreicht, Skimmer & Osmose','\n','wurden abgeschaltet'].join('')));
                      }, 5000);
                      (function () {if (timeout_ein) {clearTimeout(timeout_ein); timeout_ein = null;}})();
                    } else {
                      timeout_ein = setTimeout(function () {
                        setStateDelayed("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, true, 20000, true);
                        setStateDelayed("javascript.0.scriptEnabled.Technik_Steuerung.Osmose_Niveau"/*scriptEnabled.Technik_Steuerung.Osmose_Niveau*/, true, 10000, false);
                      }, 2000);
                      (function () {if (timeout_aus) {clearTimeout(timeout_aus); timeout_aus = null;}})();
                    }
                  });
                  on({id: 'sonoff.0.Aqua_Power.POWER3', change: "ne"}, function (obj) {
                    var value = obj.state.val;
                    var oldValue = obj.oldState.val;
                    if (getState("sonoff.0.Aqua_Power.POWER3").val == true) {
                      sendTo("telegram.0", "send", {
                          text: (['Filter Max unterschritten, Skimmer & Osmose','\n','wurden wieder eingeschaltet'].join(''))
                      });
                      console.log((['Filter Max unterschritten, Skimmer & Osmose','\n','wurden wieder eingeschsaltet'].join('')));
                    }
                  });
                  
                  paul53 1 Reply Last reply Reply Quote 0
                  • paul53
                    paul53 @Aphofis last edited by

                    @Aphofis sagte:

                    So sollte es dann ja laufen.

                    Ja, sollte es.

                    Aphofis 1 Reply Last reply Reply Quote 0
                    • Aphofis
                      Aphofis @paul53 last edited by

                      @paul53
                      Kann man es auch so benutzen !?

                      var text_aus, text_ein, timeout_aus, timeout_ein;
                      
                      
                      text_aus = ['Filter Max unterschritten, Skimmer & Osmose','\n','wurden wieder eingeschaltet'].join('');
                      text_ein = ['Filter Max erreicht, Skimmer & Osmose','\n','wurden abgeschaltet'].join('');
                      on({id: 'sonoff.0.Aqua_Float.POWER4', change: "ne"}, function (obj) {
                        var value = obj.state.val;
                        var oldValue = obj.oldState.val;
                        if ((obj.state ? obj.state.val : "")) {
                          timeout_aus = setTimeout(function () {
                            setState("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, false);
                            setState("javascript.0.scriptEnabled.Technik_Steuerung.Osmose_Niveau"/*scriptEnabled.Technik_Steuerung.Osmose_Niveau*/, false);
                            setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                            sendTo("telegram.0", "send", {
                                text: text_ein
                            });
                            console.log(text_ein);
                          }, 5000);
                          (function () {if (timeout_ein) {clearTimeout(timeout_ein); timeout_ein = null;}})();
                        } else {
                          timeout_ein = setTimeout(function () {
                            setStateDelayed("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, true, 20000, true);
                            setStateDelayed("javascript.0.scriptEnabled.Technik_Steuerung.Osmose_Niveau"/*scriptEnabled.Technik_Steuerung.Osmose_Niveau*/, true, 10000, false);
                          }, 2000);
                          (function () {if (timeout_aus) {clearTimeout(timeout_aus); timeout_aus = null;}})();
                        }
                      });
                      
                      on({id: 'sonoff.0.Aqua_Power.POWER3', change: "ne"}, function (obj) {
                        var value = obj.state.val;
                        var oldValue = obj.oldState.val;
                        if ((obj.state ? obj.state.val : "") == true) {
                          sendTo("telegram.0", "send", {
                              text: text_aus
                          });
                          console.log(text_aus);
                        }
                      });
                      
                      
                      paul53 2 Replies Last reply Reply Quote 0
                      • paul53
                        paul53 @Aphofis last edited by

                        @Aphofis sagte:

                        Kann man es auch so benutzen !?

                        Ja, aber sind nicht ein und aus in der Variablenbezeichnung vertauscht ?

                        Aphofis 1 Reply Last reply Reply Quote 0
                        • Aphofis
                          Aphofis @paul53 last edited by Aphofis

                          @paul53 ja hatte ich auch schon gemerkt!?
                          Ist es möglich das du mir bei meiner Osmose Steuerung helfen kannst !? Sonst kann ich heute Nacht nicht in Ruhe schlafen !
                          Eben wurden wieder 3 Liter zu viel dosiert obwohl Schwimmer false war.

                          true Abfrage alle 2 Sek.

                          paul53 3 Replies Last reply Reply Quote 0
                          • paul53
                            paul53 @Aphofis last edited by

                            @Aphofis
                            Sind 300 s anfägliche Restzeit richtig ?

                            Aphofis 1 Reply Last reply Reply Quote 0
                            • Aphofis
                              Aphofis @paul53 last edited by

                              @paul53
                              Ja 300 Sek. Sind ca 10 Liter die aber auf den Tag verteilt dosiert werden sollen je nach True Zustand des Schwimmers und nicht alles auf einmal

                              1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 @Aphofis last edited by

                                @Aphofis sagte:

                                Eben wurden wieder 3 Liter zu viel dosiert obwohl Schwimmer false war.

                                Das kann nicht am Skript liegen, denn das fragt den Schwimmer alle 2 s ab. Läuft vielleicht noch ein anderes Skript, welches das Magnetventil schaltet ?

                                Aphofis 1 Reply Last reply Reply Quote 0
                                • Aphofis
                                  Aphofis @paul53 last edited by

                                  @paul53
                                  Nein das sind die einzigen beiden !
                                  Osmose Niveau und Filter Max
                                  Nur die gesamte Steuerung wird abgeschaltet zb bei Futter Pause wenn alle Pumpen aus sind und später wieder eingeschaltet.

                                  Aphofis paul53 2 Replies Last reply Reply Quote 0
                                  • Aphofis
                                    Aphofis @Aphofis last edited by Aphofis

                                    @paul53
                                    Kann es sein das zb durch Filter Max die Osmose Steuerung ausgeschaltet wurde pi hat neu gestartet und Magnet Ventil ist auf true geblieben und durch abschalten der Osmose Steuerung ist das Magnet Ventil weiterhin auf true geblieben.
                                    Kann man sowas nicht irgendwie mit einbinden das magnetventil und Vlies Motor vorher abgeschaltet werden bevor der pi neu startet !? So wie zb die telegram Nachricht kommt das die Adapter gestoppt wurden weil der pi neu startet. Das muss ja nur ein kurzer Befehl sein der schnell reagiert um zu verhindern das die beiden Geräte bei Neustart weiter laufen. Nur worauf die reagieren könnten weiß ich nicht.

                                    Asgothian 1 Reply Last reply Reply Quote 0
                                    • paul53
                                      paul53 @Aphofis last edited by

                                      @Aphofis
                                      Wie oft muss ich noch schreiben, dass man Funktionen nicht per "javascript.0.scriptEnabled.Techniksteuerung.Osmose_Niveau" steuert !!
                                      Wenn dadurch das das Skript "Osmose_Niveau" gestartet wird, wird jedesmal die Restzeit auf 300 s gesetzt.

                                      1 Reply Last reply Reply Quote 0
                                      • Asgothian
                                        Asgothian Developer @Aphofis last edited by

                                        @Aphofis

                                        Ein Abschalten bei "geplantem" herunterfahren mag noch gehen. Dann bleibt trotzdem das Risiko eines Crashes des ioBroker.

                                        Wenn du deine Scripte absichern willst sind meiner Meinung nach 3 Dinge Notwendig:

                                        • Ablegen der Restlaufzeit in einem Datenpunkt, nicht in einer Variablen. Damit wird die Restlaufzeit nicht bei Scriptstart initialisiert sondern nur um Mitternacht.
                                        • bei Scriptstart prüfen ob die Magnetventile an sind, incl. Abprüfen der Zeit der letzten Änderung (Einschaltzeitpunkt) um die Restlaufzeit anzupassen
                                        • nach dem Anpassen der Restzeit den ist-zustand der Sensoren prüfen und danach die Magnetventile auf ihren Soll-Stand bringen.

                                        Ob das sauber in Blockly abbildbar ist weiss ich nicht.

                                        A.

                                        1 Reply Last reply Reply Quote 0
                                        • paul53
                                          paul53 @Aphofis last edited by

                                          @Aphofis sagte:

                                          Nur die gesamte Steuerung wird abgeschaltet zb bei Futter Pause wenn alle Pumpen aus sind und später wieder eingeschaltet.

                                          Wie wird sie ausgeschaltet ? Hoffentlich nicht dadurch, dass Skripte gestoppt werden !

                                          1 Reply Last reply Reply Quote 0
                                          • paul53
                                            paul53 @Aphofis last edited by paul53

                                            @Aphofis
                                            Mein Vorschlag: Führe beide Skripte zu einem zusammen, erstelle eine weitere Variable Osmosefreigabe, die zusätzlich zur Restzeit und dem "normalen" Schwimmer abgefragt wird.

                                            Blockly_temp.JPG

                                            Wie @Asgothian geschrieben hat: Damit die Restzeit auch stimmt, wenn der Pi oder ioBroker neu gestartet wird, sollte die Restzeit bei jeder Änderung in einen Datenpunkt gespeichert werden, der bei Skriptstart in die Variable Restzeit geladen wird.

                                            Aphofis 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            542
                                            Online

                                            32.0k
                                            Users

                                            80.4k
                                            Topics

                                            1.3m
                                            Posts

                                            4
                                            262
                                            16348
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo