Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Blockly
  5. [gelöst] Schaltzustand Verzögern

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    823

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

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

[gelöst] Schaltzustand Verzögern

Scheduled Pinned Locked Moved Blockly
262 Posts 4 Posters 25.6k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • AphofisA Aphofis

    @paul53
    Na toll

    paul53P Offline
    paul53P Offline
    paul53
    wrote on last edited by
    #72

    @Aphofis
    Nimm diese:
    Osmose.js.txt

    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

    AphofisA 1 Reply Last reply
    0
    • paul53P paul53

      @Aphofis
      Nimm diese:
      Osmose.js.txt

      AphofisA Offline
      AphofisA Offline
      Aphofis
      wrote on last edited by Aphofis
      #73

      @paul53
      Da fehlt dann nur

       log('Schwimmer: ' + Schwimmer); 
      
      paul53P 1 Reply Last reply
      0
      • AphofisA Aphofis

        @paul53
        Da fehlt dann nur

         log('Schwimmer: ' + Schwimmer); 
        
        paul53P Offline
        paul53P Offline
        paul53
        wrote on last edited by
        #74

        @Aphofis sagte:

        Da fehlt dann nur

        Wo ?

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

        AphofisA 1 Reply Last reply
        0
        • paul53P paul53

          @Aphofis sagte:

          Da fehlt dann nur

          Wo ?

          AphofisA Offline
          AphofisA Offline
          Aphofis
          wrote on last edited by
          #75

          @paul53
          In der txt die ich nehmen sollte oder ist der Log da schon irgendwo drin?

          paul53P 1 Reply Last reply
          0
          • AphofisA Aphofis

            @paul53
            In der txt die ich nehmen sollte oder ist der Log da schon irgendwo drin?

            paul53P Offline
            paul53P Offline
            paul53
            wrote on last edited by
            #76

            @Aphofis sagte:

            ist der Log da schon irgendwo drin?

            Zeile 36.

            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

            AphofisA 1 Reply Last reply
            0
            • paul53P paul53

              @Aphofis sagte:

              ist der Log da schon irgendwo drin?

              Zeile 36.

              AphofisA Offline
              AphofisA Offline
              Aphofis
              wrote on last edited by
              #77

              @paul53 Das hab ich wohl nicht so ganz gefunden!
              Wird wohl auch noch eine Zeit dauern, bis ich JS lesen kann

              AphofisA 1 Reply Last reply
              0
              • AphofisA Aphofis

                @paul53 Das hab ich wohl nicht so ganz gefunden!
                Wird wohl auch noch eine Zeit dauern, bis ich JS lesen kann

                AphofisA Offline
                AphofisA Offline
                Aphofis
                wrote on last edited by
                #78

                @paul53
                Bis jetzt macht die Osmose Steuerung was sie soll!
                Wird nicht zu viel dosiert und Filter Max wurde seid gestern Abend nicht erreicht

                paul53P 1 Reply Last reply
                0
                • AphofisA Aphofis

                  @paul53
                  Bis jetzt macht die Osmose Steuerung was sie soll!
                  Wird nicht zu viel dosiert und Filter Max wurde seid gestern Abend nicht erreicht

                  paul53P Offline
                  paul53P Offline
                  paul53
                  wrote on last edited by
                  #79

                  @Aphofis sagte:

                  Wird nicht zu viel dosiert

                  Wenn vorher zuviel dosiert wurde, dann war die Abfrage des Schwimmers alle 2 Sekunden zu langsam. Jetzt wird direkt auf den Schwimmer reagiert.

                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                  AphofisA 1 Reply Last reply
                  0
                  • paul53P paul53

                    @Aphofis sagte:

                    Wird nicht zu viel dosiert

                    Wenn vorher zuviel dosiert wurde, dann war die Abfrage des Schwimmers alle 2 Sekunden zu langsam. Jetzt wird direkt auf den Schwimmer reagiert.

                    AphofisA Offline
                    AphofisA Offline
                    Aphofis
                    wrote on last edited by
                    #80

                    @paul53
                    klingt toll aber heute wurde wieder bis filter max true war dosiert.
                    bringt es was den wert auf 500 ms zu stellen???

                    paul53P 1 Reply Last reply
                    0
                    • AphofisA Aphofis

                      @paul53
                      klingt toll aber heute wurde wieder bis filter max true war dosiert.
                      bringt es was den wert auf 500 ms zu stellen???

                      paul53P Offline
                      paul53P Offline
                      paul53
                      wrote on last edited by paul53
                      #81

                      @Aphofis sagte:

                      bringt es was den wert auf 500 ms zu stellen???

                      Nein, das Magnetventil wird direkt vom Trigger des Schwimmers geschlossen. Schneller geht es per Software (JS) nicht. Die Frage ist, ob das setState() wirklich zuverlässig das Ventil steuert oder es bei zuviel Verkehr im 2,4-GHz-Band ins Leere läuft, bzw. ob jedes Schwimmer-Signal zuverlässig in ioBroker ankommt.
                      Wenn der Schwimmer noch einen zweiten potentialfreien Kontakt hat, würde ich ihn in Reihe (UND-Verknüpfung) zwischen Sonoff-Aktor und Magnetventil schalten.

                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                      AphofisA 1 Reply Last reply
                      0
                      • paul53P paul53

                        @Aphofis sagte:

                        bringt es was den wert auf 500 ms zu stellen???

                        Nein, das Magnetventil wird direkt vom Trigger des Schwimmers geschlossen. Schneller geht es per Software (JS) nicht. Die Frage ist, ob das setState() wirklich zuverlässig das Ventil steuert oder es bei zuviel Verkehr im 2,4-GHz-Band ins Leere läuft, bzw. ob jedes Schwimmer-Signal zuverlässig in ioBroker ankommt.
                        Wenn der Schwimmer noch einen zweiten potentialfreien Kontakt hat, würde ich ihn in Reihe (UND-Verknüpfung) zwischen Sonoff-Aktor und Magnetventil schalten.

                        AphofisA Offline
                        AphofisA Offline
                        Aphofis
                        wrote on last edited by Aphofis
                        #82

                        @paul53 nein leider nicht es sind normale Schwimmer mit einem pull-up Widerstand dazwischen mehr nicht

                        4AB02CC9-69A7-4195-912C-63E0CB598CF2.jpeg
                        Kann man nicht die sende Intervalle vom ESP8266 verkürzen !?

                        paul53P 1 Reply Last reply
                        0
                        • AphofisA Aphofis

                          @paul53 nein leider nicht es sind normale Schwimmer mit einem pull-up Widerstand dazwischen mehr nicht

                          4AB02CC9-69A7-4195-912C-63E0CB598CF2.jpeg
                          Kann man nicht die sende Intervalle vom ESP8266 verkürzen !?

                          paul53P Offline
                          paul53P Offline
                          paul53
                          wrote on last edited by
                          #83

                          @Aphofis sagte:

                          Kann man nicht die sende Intervalle vom ESP8266 verkürzen !?

                          Keine Ahnung, mit dem WLAN-Zeugs kenne ich mich nicht aus, da ich es nicht verwende.

                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                          AphofisA 1 Reply Last reply
                          0
                          • paul53P paul53

                            @Aphofis sagte:

                            Kann man nicht die sende Intervalle vom ESP8266 verkürzen !?

                            Keine Ahnung, mit dem WLAN-Zeugs kenne ich mich nicht aus, da ich es nicht verwende.

                            AphofisA Offline
                            AphofisA Offline
                            Aphofis
                            wrote on last edited by
                            #84

                            @paul53
                            Naja ich kenne mich eigntl damit aus!
                            Nur vllt liegt es an was anderem.
                            hatte jetzt 2 liter wasser raus Filter max ist false aber Skimmer wird nicht wieder eingeschaltet. Relais ist aus und im Sonoff andapter ist er auch false
                            Das meine ich damit wenn ich sage Blockly ist mir lieber! da ich dann selbst guchen kann. Bei einem JS weiß ich nicht wie ich die einzelnen Datenpunkte kontrollieren soll.

                            1 Reply Last reply
                            0
                            • AphofisA Offline
                              AphofisA Offline
                              Aphofis
                              wrote on last edited by
                              #85

                              Datenpunkte zum Skimmer

                              sonoff.0.Aqua_Power.POWER3
                              

                              sind alle richtog gesetzt

                              1 Reply Last reply
                              0
                              • AphofisA Offline
                                AphofisA Offline
                                Aphofis
                                wrote on last edited by
                                #86

                                @paul53
                                ist hier denn alles Korrekt an Code!?

                                const idRestzeit = 'Osmose.Restzeit';
                                const text_ein = ['Filter Max unterschritten, Skimmer & Osmose','\n','wurden wieder eingeschaltet'].join('');
                                const text_aus = ['Filter Max erreicht, Skimmer & Osmose','\n','wurden abgeschaltet'].join('');
                                
                                createState(idRestzeit, 300, {type: 'number', unit: 's'});
                                
                                var Osmosefreigabe = !getState('sonoff.0.Aqua_Float.POWER4').val;
                                var Schwimmer = getState("sonoff.0.Aqua_Float.POWER1").val;
                                var Restzeit, timeout_aus, timeout_ein, Magnetventil_Kontrolle;
                                
                                function Magnetventil_Ein() {
                                  if (!Magnetventil_Kontrolle && Restzeit > 0 && Osmosefreigabe) {
                                    Magnetventil_Kontrolle = setInterval(function () {
                                      if (Restzeit > 0 && Schwimmer && Osmosefreigabe) {
                                        Restzeit--;
                                        setState(idRestzeit, 2 * Restzeit, true);
                                      } else {
                                        setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                        clearInterval(Magnetventil_Kontrolle); 
                                        Magnetventil_Kontrolle = null;
                                      }
                                    }, 2000);
                                    setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, true);
                                  }
                                }
                                
                                // Skripstart
                                setTimeout(function() {
                                    Restzeit = getState(idRestzeit).val / 2;
                                    if(Schwimmer && Osmosefreigabe) Magnetventil_Ein();
                                    else setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                }, 200);
                                
                                on({id: 'sonoff.0.Aqua_Float.POWER1', change: "ne"}, function (obj) {
                                  Schwimmer = obj.state.val;
                                  log('Schwimmer: ' + Schwimmer)
                                  if(Schwimmer) Magnetventil_Ein();
                                  else setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                });
                                
                                schedule("0 0 * * *", function () {
                                  Restzeit = 150;
                                  setState(idRestzeit, 300, true);
                                  if(Schwimmer) Magnetventil_Ein();
                                });
                                
                                on({id: 'sonoff.0.Aqua_Float.POWER4', change: "ne"}, function (obj) {
                                  if (obj.state.val) {
                                    timeout_aus = setTimeout(function () {
                                      Osmosefreigabe = false;  
                                      setState("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, false);
                                      setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                    }, 5000);
                                    if (timeout_ein) {
                                        clearTimeout(timeout_ein); 
                                        timeout_ein = null;
                                    }
                                  } else {
                                    timeout_ein = setTimeout(function () {
                                      Osmosefreigabe = true;
                                      if(Schwimmer) Magnetventil_Ein();           
                                      setStateDelayed("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, true, 10000);
                                    }, 10000);
                                    if (timeout_aus) {
                                        clearTimeout(timeout_aus); 
                                        timeout_aus = null;
                                    }
                                  }
                                });
                                 
                                on({id: 'sonoff.0.Aqua_Power.POWER3', change: "ne"}, function (obj) {
                                  var txt;  
                                  if (obj.state.val) txt = text_ein;   
                                  else txt = text_aus;   
                                  sendTo("telegram.0", "send", {
                                    text: txt
                                  });
                                  log(txt);
                                });
                                
                                paul53P 1 Reply Last reply
                                0
                                • AphofisA Aphofis

                                  @paul53
                                  ist hier denn alles Korrekt an Code!?

                                  const idRestzeit = 'Osmose.Restzeit';
                                  const text_ein = ['Filter Max unterschritten, Skimmer & Osmose','\n','wurden wieder eingeschaltet'].join('');
                                  const text_aus = ['Filter Max erreicht, Skimmer & Osmose','\n','wurden abgeschaltet'].join('');
                                  
                                  createState(idRestzeit, 300, {type: 'number', unit: 's'});
                                  
                                  var Osmosefreigabe = !getState('sonoff.0.Aqua_Float.POWER4').val;
                                  var Schwimmer = getState("sonoff.0.Aqua_Float.POWER1").val;
                                  var Restzeit, timeout_aus, timeout_ein, Magnetventil_Kontrolle;
                                  
                                  function Magnetventil_Ein() {
                                    if (!Magnetventil_Kontrolle && Restzeit > 0 && Osmosefreigabe) {
                                      Magnetventil_Kontrolle = setInterval(function () {
                                        if (Restzeit > 0 && Schwimmer && Osmosefreigabe) {
                                          Restzeit--;
                                          setState(idRestzeit, 2 * Restzeit, true);
                                        } else {
                                          setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                          clearInterval(Magnetventil_Kontrolle); 
                                          Magnetventil_Kontrolle = null;
                                        }
                                      }, 2000);
                                      setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, true);
                                    }
                                  }
                                  
                                  // Skripstart
                                  setTimeout(function() {
                                      Restzeit = getState(idRestzeit).val / 2;
                                      if(Schwimmer && Osmosefreigabe) Magnetventil_Ein();
                                      else setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                  }, 200);
                                  
                                  on({id: 'sonoff.0.Aqua_Float.POWER1', change: "ne"}, function (obj) {
                                    Schwimmer = obj.state.val;
                                    log('Schwimmer: ' + Schwimmer)
                                    if(Schwimmer) Magnetventil_Ein();
                                    else setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                  });
                                  
                                  schedule("0 0 * * *", function () {
                                    Restzeit = 150;
                                    setState(idRestzeit, 300, true);
                                    if(Schwimmer) Magnetventil_Ein();
                                  });
                                  
                                  on({id: 'sonoff.0.Aqua_Float.POWER4', change: "ne"}, function (obj) {
                                    if (obj.state.val) {
                                      timeout_aus = setTimeout(function () {
                                        Osmosefreigabe = false;  
                                        setState("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, false);
                                        setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                      }, 5000);
                                      if (timeout_ein) {
                                          clearTimeout(timeout_ein); 
                                          timeout_ein = null;
                                      }
                                    } else {
                                      timeout_ein = setTimeout(function () {
                                        Osmosefreigabe = true;
                                        if(Schwimmer) Magnetventil_Ein();           
                                        setStateDelayed("sonoff.0.Aqua_Power.POWER3"/*Aqua_Power_Skimmer*/, true, 10000);
                                      }, 10000);
                                      if (timeout_aus) {
                                          clearTimeout(timeout_aus); 
                                          timeout_aus = null;
                                      }
                                    }
                                  });
                                   
                                  on({id: 'sonoff.0.Aqua_Power.POWER3', change: "ne"}, function (obj) {
                                    var txt;  
                                    if (obj.state.val) txt = text_ein;   
                                    else txt = text_aus;   
                                    sendTo("telegram.0", "send", {
                                      text: txt
                                    });
                                    log(txt);
                                  });
                                  
                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  wrote on last edited by
                                  #87

                                  @Aphofis sagte:

                                  ist hier denn alles Korrekt an Code!?

                                  Ja.

                                  @Aphofis sagte in Schaltzustand Verzögern:

                                  Filter max ist false aber Skimmer wird nicht wieder eingeschaltet.

                                  Der Skimmer wird durch das Skript nach 20 s eingeschaltet, nachdem der Max-Schwimmer auf false wechselt (Zeile 62).

                                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                  AphofisA 1 Reply Last reply
                                  0
                                  • paul53P paul53

                                    @Aphofis sagte:

                                    ist hier denn alles Korrekt an Code!?

                                    Ja.

                                    @Aphofis sagte in Schaltzustand Verzögern:

                                    Filter max ist false aber Skimmer wird nicht wieder eingeschaltet.

                                    Der Skimmer wird durch das Skript nach 20 s eingeschaltet, nachdem der Max-Schwimmer auf false wechselt (Zeile 62).

                                    AphofisA Offline
                                    AphofisA Offline
                                    Aphofis
                                    wrote on last edited by
                                    #88

                                    @paul53
                                    tut's nur leider nicht!!!
                                    Per Datenpunkt lässt sich der Skimmer tadellos einschalten.
                                    Gibt es in dem JS eine Kontrolle die den Skimmer kontrolliert bei Filter max false !?

                                    paul53P 1 Reply Last reply
                                    0
                                    • AphofisA Aphofis

                                      @paul53
                                      tut's nur leider nicht!!!
                                      Per Datenpunkt lässt sich der Skimmer tadellos einschalten.
                                      Gibt es in dem JS eine Kontrolle die den Skimmer kontrolliert bei Filter max false !?

                                      paul53P Offline
                                      paul53P Offline
                                      paul53
                                      wrote on last edited by
                                      #89

                                      @Aphofis sagte:

                                      Gibt es in dem JS eine Kontrolle die den Skimmer kontrolliert bei Filter max false !?

                                      Nein, er wird nur abhängig vom Max-Schwimmer gesteuert.

                                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                      AphofisA 1 Reply Last reply
                                      0
                                      • paul53P paul53

                                        @Aphofis sagte:

                                        Gibt es in dem JS eine Kontrolle die den Skimmer kontrolliert bei Filter max false !?

                                        Nein, er wird nur abhängig vom Max-Schwimmer gesteuert.

                                        AphofisA Offline
                                        AphofisA Offline
                                        Aphofis
                                        wrote on last edited by
                                        #90

                                        @paul53
                                        Code technisch ja aber er war nach dem ich 2 liter wasser raus hatte und Filter max false war auch nach minuten nicht wieder eingeschaltet.

                                        paul53P 1 Reply Last reply
                                        0
                                        • AphofisA Aphofis

                                          @paul53
                                          Code technisch ja aber er war nach dem ich 2 liter wasser raus hatte und Filter max false war auch nach minuten nicht wieder eingeschaltet.

                                          paul53P Offline
                                          paul53P Offline
                                          paul53
                                          wrote on last edited by
                                          #91

                                          @Aphofis sagte:

                                          Filter max false war auch nach minuten nicht wieder eingeschaltet.

                                          Dann har er entweder bei Änderung des Max-Schwimmers nicht getriggert (warum auch immer ??) oder innerhalb der 20 s ist etwas passiert, was das Skript durcheinander gebracht hat (z.B. Skript-Restart).

                                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                          AphofisA 1 Reply Last reply
                                          0

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          563

                                          Online

                                          32.8k

                                          Users

                                          82.7k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe