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. Blockly
  5. [gelöst] Schaltzustand Verzögern

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.0k

[gelöst] Schaltzustand Verzögern

Geplant Angeheftet Gesperrt Verschoben Blockly
262 Beiträge 4 Kommentatoren 22.9k Aufrufe 2 Watching
  • Ä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.
  • AphofisA Aphofis

    @paul53
    Na toll

    paul53P Offline
    paul53P Offline
    paul53
    schrieb am zuletzt editiert von
    #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 Antwort Letzte Antwort
    0
    • paul53P paul53

      @Aphofis
      Nimm diese:
      Osmose.js.txt

      AphofisA Offline
      AphofisA Offline
      Aphofis
      schrieb am zuletzt editiert von Aphofis
      #73

      @paul53
      Da fehlt dann nur

       log('Schwimmer: ' + Schwimmer); 
      
      paul53P 1 Antwort Letzte Antwort
      0
      • AphofisA Aphofis

        @paul53
        Da fehlt dann nur

         log('Schwimmer: ' + Schwimmer); 
        
        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        0
        • paul53P paul53

          @Aphofis sagte:

          Da fehlt dann nur

          Wo ?

          AphofisA Offline
          AphofisA Offline
          Aphofis
          schrieb am zuletzt editiert von
          #75

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

          paul53P 1 Antwort Letzte Antwort
          0
          • AphofisA Aphofis

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

            paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            0
            • paul53P paul53

              @Aphofis sagte:

              ist der Log da schon irgendwo drin?

              Zeile 36.

              AphofisA Offline
              AphofisA Offline
              Aphofis
              schrieb am zuletzt editiert von
              #77

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

              AphofisA 1 Antwort Letzte Antwort
              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
                schrieb am zuletzt editiert von
                #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 Antwort Letzte Antwort
                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
                  schrieb am zuletzt editiert von
                  #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 Antwort Letzte Antwort
                  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
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    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
                      schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                      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
                        schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                        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
                          schrieb am zuletzt editiert von
                          #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 Antwort Letzte Antwort
                          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
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            0
                            • AphofisA Offline
                              AphofisA Offline
                              Aphofis
                              schrieb am zuletzt editiert von
                              #85

                              Datenpunkte zum Skimmer

                              sonoff.0.Aqua_Power.POWER3
                              

                              sind alle richtog gesetzt

                              1 Antwort Letzte Antwort
                              0
                              • AphofisA Offline
                                AphofisA Offline
                                Aphofis
                                schrieb am zuletzt editiert von
                                #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 Antwort Letzte Antwort
                                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
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  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
                                    schrieb am zuletzt editiert von
                                    #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 Antwort Letzte Antwort
                                    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
                                      schrieb am zuletzt editiert von
                                      #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 Antwort Letzte Antwort
                                      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
                                        schrieb am zuletzt editiert von
                                        #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 Antwort Letzte Antwort
                                        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
                                          schrieb am zuletzt editiert von
                                          #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 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

                                          281

                                          Online

                                          32.6k

                                          Benutzer

                                          82.0k

                                          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