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] Osmose Wasser Aktuell & Max Verbrauch

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    507

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.7k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.6k

[gelöst] Osmose Wasser Aktuell & Max Verbrauch

Geplant Angeheftet Gesperrt Verschoben Blockly
79 Beiträge 2 Kommentatoren 3.1k Aufrufe 1 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.
  • paul53P paul53

    @Aphofis sagte:

    Wäre das so korrekt?

    Nein, Zeile 4 muss als erstes innerhalb des Schedule ausgeführt werden, da der Wert sonst nur einmal bei Skriptstart ermittelt wird.

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

    @paul53
    also so?

    var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
    
    
    Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
    schedule("59 23 * * *", function () {
      setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
      Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
    });
    
    paul53P 1 Antwort Letzte Antwort
    0
    • AphofisA Aphofis

      @paul53
      also so?

      var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
      
      
      Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
      schedule("59 23 * * *", function () {
        setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
        Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
      });
      
      paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von
      #56

      @Aphofis sagte:

      also so?

      Nein, so:

      var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
       
       
      schedule("59 23 * * *", function () {
        Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
        Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
        setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
      });
      

      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:

        also so?

        Nein, so:

        var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
         
         
        schedule("59 23 * * *", function () {
          Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
          Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
          setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
        });
        
        AphofisA Offline
        AphofisA Offline
        Aphofis
        schrieb am zuletzt editiert von Aphofis
        #57

        @paul53
        OK hab ich !

        var Triton_L_C3_B6sung_2_F_C3_BCllstand, Abzug;
        
        
        schedule("59 23 * * *", function () {
          Triton_L_C3_B6sung_2_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand").val;
          Abzug = Triton_L_C3_B6sung_2_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand").val;
          setState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand"/*Triton_Lösung_2_Füllstand*/, Abzug, true);
        });
        
        1 Antwort Letzte Antwort
        0
        • AphofisA Offline
          AphofisA Offline
          Aphofis
          schrieb am zuletzt editiert von
          #58

          @paul53
          Ich hatte das so erstellt, nur leider wird so nix von dem Füllstand Datenpunkt (5000ml) abgezogen.

          var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
          
          
          schedule("59 23 * * *", function () {
            Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
            Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
            setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
          });
          

          vorher war es so:

          var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
          
          
          Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
          schedule("59 23 * * *", function () {
            Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
            setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
          });
          

          Da wurde vom Füllstand Datenpunkt abgezogen. vllt sollte ich nicht ml_pro_Tag abziehen sindern jedes mal nur ml_Aktuell dann ist es vllt einfacher ohne die Zeit Steuerung um 23:59

          paul53P 1 Antwort Letzte Antwort
          0
          • AphofisA Aphofis

            @paul53
            Ich hatte das so erstellt, nur leider wird so nix von dem Füllstand Datenpunkt (5000ml) abgezogen.

            var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
            
            
            schedule("59 23 * * *", function () {
              Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
              Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
              setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
            });
            

            vorher war es so:

            var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
            
            
            Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
            schedule("59 23 * * *", function () {
              Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
              setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
            });
            

            Da wurde vom Füllstand Datenpunkt abgezogen. vllt sollte ich nicht ml_pro_Tag abziehen sindern jedes mal nur ml_Aktuell dann ist es vllt einfacher ohne die Zeit Steuerung um 23:59

            paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #59

            @Aphofis sagte:

            leider wird so nix von dem Füllstand Datenpunkt (5000ml) abgezogen.

            Der Abzug des Tagesverbrauchs erfolgt täglich um 23:59 Uhr.

            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:

              leider wird so nix von dem Füllstand Datenpunkt (5000ml) abgezogen.

              Der Abzug des Tagesverbrauchs erfolgt täglich um 23:59 Uhr.

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

              @paul53
              Ich bin schon ganz wuschig!
              Ja na klar ich stand mal wieder im Wald!

              1 Antwort Letzte Antwort
              0
              • AphofisA Offline
                AphofisA Offline
                Aphofis
                schrieb am zuletzt editiert von
                #61

                @paul53
                ist es so nicht auch möglich!?
                immer wenn der aktuelle wert geändert wurde das dann vom Füllstand abgezogen wird!?

                var Triton_L_C3_B6sung_2_F_C3_BCllstand, Abzug;
                
                
                Triton_L_C3_B6sung_2_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand").val;
                on({id: 'Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Aktuell_2', change: "ne"}, function (obj) {
                  var value = obj.state.val;
                  var oldValue = obj.oldState.val;
                  Abzug = Triton_L_C3_B6sung_2_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Aktuell_2").val;
                  setState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand"/*Triton_Lösung_2_Füllstand*/, Abzug, true);
                });
                
                paul53P 1 Antwort Letzte Antwort
                0
                • AphofisA Aphofis

                  @paul53
                  ist es so nicht auch möglich!?
                  immer wenn der aktuelle wert geändert wurde das dann vom Füllstand abgezogen wird!?

                  var Triton_L_C3_B6sung_2_F_C3_BCllstand, Abzug;
                  
                  
                  Triton_L_C3_B6sung_2_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand").val;
                  on({id: 'Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Aktuell_2', change: "ne"}, function (obj) {
                    var value = obj.state.val;
                    var oldValue = obj.oldState.val;
                    Abzug = Triton_L_C3_B6sung_2_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Aktuell_2").val;
                    setState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand"/*Triton_Lösung_2_Füllstand*/, Abzug, true);
                  });
                  
                  paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von
                  #62

                  @Aphofis sagte:

                  ist es so nicht auch möglich!?

                  Ja, wenn "Triton_Aktuell_2" ein kumulativer Wert ist, sich also ständig erhöht.

                  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 es so nicht auch möglich!?

                    Ja, wenn "Triton_Aktuell_2" ein kumulativer Wert ist, sich also ständig erhöht.

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

                    @paul53
                    ne ne leider nicht also z.B.
                    Lösung 1 ist momentan auf den Tag verteilt alle 4 Std 3 - 3 - 3 - 2 - 2 - 2 ml
                    Lösung 2, 3a und 3b sind 6 mal 2 ml also bleibt der aktuell Wert eigntl immer gleich bis auf der wechsel zwischen 3 und 2 ml ansonsten ist er immer gleich

                    Ich weiß nicht wie man es man das sobald aktuell dosiert wurde egal ob der wert gleich ist oder sich geändert hat dann abgezogen wird.
                    z.B. eben um 23:59 wurde von Lösung 1 vom Füllstand die Tagesmenge abgezogen die Füllstände von Lösung 2, 3a und 3b wurden einfach auf null gesetzt. Obgleich alle vier Steuerungen gleich sind.

                    paul53P 1 Antwort Letzte Antwort
                    0
                    • AphofisA Offline
                      AphofisA Offline
                      Aphofis
                      schrieb am zuletzt editiert von
                      #64

                      @paul53
                      Es gibt leider noch ein Problem!
                      Wenn zb der ESP mal nicht erreichbar ist und dann wieder erreichbar ist, scheint es so das true oder false nicht geprüft werden. Da nach dem neu verbinden des ESP mit dem Sonoff Adapter in Iobroker wird keine Osmose dosiert.
                      Was das Script ja eigntl machen sollte.

                      var Restzeit, Magnetventil_Kontrolle, Magnetventil_Kontrolle, timeout;
                      
                      /**
                       * Beschreibe diese Funktion …
                       */
                      function Magnetventil_Ein() {
                        if (!Magnetventil_Kontrolle && Restzeit > 0) {
                          Magnetventil_Kontrolle = setInterval(function () {
                            if (Restzeit > 0 && getState("sonoff.0.Aqua_Float.POWER1").val) {
                              Restzeit = (typeof Restzeit == 'number' ? Restzeit : 0) + -1;
                            } else {
                              setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                              (function () {if (Magnetventil_Kontrolle) {clearInterval(Magnetventil_Kontrolle); Magnetventil_Kontrolle = null;}})();
                              sendTo("telegram.0", "send", {
                                  text: ('Magnetventil ist eingeschaltet')
                              });
                            }
                          }, 2000);
                          setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, true);
                          timeout = setTimeout(function () {
                            sendTo("telegram.0", "send", {
                                text: ('Magnetventil ist ausgeschaltet')
                            });
                          }, 4000);
                          (function () {if (timeout) {clearTimeout(timeout); timeout = null;}})();
                        }
                      }
                      
                      
                      Restzeit = 150;
                      Magnetventil_Kontrolle = null;
                      
                      on({id: 'sonoff.0.Aqua_Float.POWER1', change: "gt"}, function (obj) {
                        var value = obj.state.val;
                        var oldValue = obj.oldState.val;
                        Magnetventil_Ein();
                      });
                      schedule("0 0 * * *", function () {
                        Restzeit = 150;
                        if (getState("sonoff.0.Aqua_Float.POWER1").val) {
                          Magnetventil_Ein();
                        }
                      });
                      

                      Nun weiß ich nicht woran es liegen könnte.
                      Ich werde Heute auch meine Fritzbox tauschen da ich vermute das die einen Knax weg hat.
                      Was das Gerät alles fröhliches treibt dauert jetzt zu lange das zu erklären. Nur so viel
                      Geräte mit fester IP werden raus geschmissen. Geräte die Einen Fritzbox internen Namen vergeben haben und eine feste IP zugewiesen bekommen haben tauchen im Netzwerk nicht mehr auf oder noch netter andere Geräte haben auf einmal den Namen eines anderen Gerätes oder noch besser werden weder im WLAN noch in der Netzwerk Liste der Geräte angezeit aber wenn man die IP adresse kennt komischerweise und viel Glück hat erreicht man das Gerät per IP adresse. gut das iobroker die Geräte per MAC Adresse verbindet bzw per MQTT.
                      da kommen noch einige Punkte dazu also Gerät tauschen ansonsten wenn das nix hilft stelle ich einen zusätzlichen 2,4 und 5 Ghz WLAN Router auf über den die Steuerungs Geräte zu meinem Aquarium fest verbunden werden und dann ist Ruhe im Karton.

                      paul53P 1 Antwort Letzte Antwort
                      0
                      • AphofisA Aphofis

                        @paul53
                        ne ne leider nicht also z.B.
                        Lösung 1 ist momentan auf den Tag verteilt alle 4 Std 3 - 3 - 3 - 2 - 2 - 2 ml
                        Lösung 2, 3a und 3b sind 6 mal 2 ml also bleibt der aktuell Wert eigntl immer gleich bis auf der wechsel zwischen 3 und 2 ml ansonsten ist er immer gleich

                        Ich weiß nicht wie man es man das sobald aktuell dosiert wurde egal ob der wert gleich ist oder sich geändert hat dann abgezogen wird.
                        z.B. eben um 23:59 wurde von Lösung 1 vom Füllstand die Tagesmenge abgezogen die Füllstände von Lösung 2, 3a und 3b wurden einfach auf null gesetzt. Obgleich alle vier Steuerungen gleich sind.

                        paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von
                        #65

                        @Aphofis sagte:

                        sobald aktuell dosiert wurde egal ob der wert gleich ist oder sich geändert hat dann abgezogen wird.

                        Unter der Vorausstzung, dass der Dosierwert nach jeder Dosierung aktualisiert wird, sollte es so funktionieren:

                        Blockly_temp.JPG

                        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

                        1 Antwort Letzte Antwort
                        1
                        • AphofisA Aphofis

                          @paul53
                          Es gibt leider noch ein Problem!
                          Wenn zb der ESP mal nicht erreichbar ist und dann wieder erreichbar ist, scheint es so das true oder false nicht geprüft werden. Da nach dem neu verbinden des ESP mit dem Sonoff Adapter in Iobroker wird keine Osmose dosiert.
                          Was das Script ja eigntl machen sollte.

                          var Restzeit, Magnetventil_Kontrolle, Magnetventil_Kontrolle, timeout;
                          
                          /**
                           * Beschreibe diese Funktion …
                           */
                          function Magnetventil_Ein() {
                            if (!Magnetventil_Kontrolle && Restzeit > 0) {
                              Magnetventil_Kontrolle = setInterval(function () {
                                if (Restzeit > 0 && getState("sonoff.0.Aqua_Float.POWER1").val) {
                                  Restzeit = (typeof Restzeit == 'number' ? Restzeit : 0) + -1;
                                } else {
                                  setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                  (function () {if (Magnetventil_Kontrolle) {clearInterval(Magnetventil_Kontrolle); Magnetventil_Kontrolle = null;}})();
                                  sendTo("telegram.0", "send", {
                                      text: ('Magnetventil ist eingeschaltet')
                                  });
                                }
                              }, 2000);
                              setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, true);
                              timeout = setTimeout(function () {
                                sendTo("telegram.0", "send", {
                                    text: ('Magnetventil ist ausgeschaltet')
                                });
                              }, 4000);
                              (function () {if (timeout) {clearTimeout(timeout); timeout = null;}})();
                            }
                          }
                          
                          
                          Restzeit = 150;
                          Magnetventil_Kontrolle = null;
                          
                          on({id: 'sonoff.0.Aqua_Float.POWER1', change: "gt"}, function (obj) {
                            var value = obj.state.val;
                            var oldValue = obj.oldState.val;
                            Magnetventil_Ein();
                          });
                          schedule("0 0 * * *", function () {
                            Restzeit = 150;
                            if (getState("sonoff.0.Aqua_Float.POWER1").val) {
                              Magnetventil_Ein();
                            }
                          });
                          

                          Nun weiß ich nicht woran es liegen könnte.
                          Ich werde Heute auch meine Fritzbox tauschen da ich vermute das die einen Knax weg hat.
                          Was das Gerät alles fröhliches treibt dauert jetzt zu lange das zu erklären. Nur so viel
                          Geräte mit fester IP werden raus geschmissen. Geräte die Einen Fritzbox internen Namen vergeben haben und eine feste IP zugewiesen bekommen haben tauchen im Netzwerk nicht mehr auf oder noch netter andere Geräte haben auf einmal den Namen eines anderen Gerätes oder noch besser werden weder im WLAN noch in der Netzwerk Liste der Geräte angezeit aber wenn man die IP adresse kennt komischerweise und viel Glück hat erreicht man das Gerät per IP adresse. gut das iobroker die Geräte per MAC Adresse verbindet bzw per MQTT.
                          da kommen noch einige Punkte dazu also Gerät tauschen ansonsten wenn das nix hilft stelle ich einen zusätzlichen 2,4 und 5 Ghz WLAN Router auf über den die Steuerungs Geräte zu meinem Aquarium fest verbunden werden und dann ist Ruhe im Karton.

                          paul53P Offline
                          paul53P Offline
                          paul53
                          schrieb am zuletzt editiert von
                          #66

                          @Aphofis
                          Javascript-Code, Zeile 1: Es gibt 2 Variablen mit dem Bezeichner Magnetventil_Kontrolle !

                          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
                            Javascript-Code, Zeile 1: Es gibt 2 Variablen mit dem Bezeichner Magnetventil_Kontrolle !

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

                            @paul53
                            und was mache ich da jetzt!?
                            falsche Variable gelöscht

                            var Restzeit, Magnetventil_Kontrolle, timeout;
                            
                            /**
                             * Beschreibe diese Funktion …
                             */
                            function Magnetventil_Ein() {
                              if (!Magnetventil_Kontrolle && Restzeit > 0) {
                                Magnetventil_Kontrolle = setInterval(function () {
                                  if (Restzeit > 0 && getState("sonoff.0.Aqua_Float.POWER1").val) {
                                    Restzeit = (typeof Restzeit == 'number' ? Restzeit : 0) + -1;
                                  } else {
                                    setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                    (function () {if (Magnetventil_Kontrolle) {clearInterval(Magnetventil_Kontrolle); Magnetventil_Kontrolle = null;}})();
                                    sendTo("telegram.0", "send", {
                                        text: ('Magnetventil ist eingeschaltet')
                                    });
                                  }
                                }, 2000);
                                setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, true);
                                timeout = setTimeout(function () {
                                  sendTo("telegram.0", "send", {
                                      text: ('Magnetventil ist ausgeschaltet')
                                  });
                                }, 4000);
                                (function () {if (timeout) {clearTimeout(timeout); timeout = null;}})();
                              }
                            }
                            
                            
                            Restzeit = 150;
                            Magnetventil_Kontrolle = null;
                            
                            on({id: 'sonoff.0.Aqua_Float.POWER1', change: "gt"}, function (obj) {
                              var value = obj.state.val;
                              var oldValue = obj.oldState.val;
                              Magnetventil_Ein();
                            });
                            schedule("0 0 * * *", function () {
                              Restzeit = 150;
                              if (getState("sonoff.0.Aqua_Float.POWER1").val) {
                                Magnetventil_Ein();
                              }
                            });
                            
                            paul53P 1 Antwort Letzte Antwort
                            0
                            • AphofisA Aphofis

                              @paul53
                              und was mache ich da jetzt!?
                              falsche Variable gelöscht

                              var Restzeit, Magnetventil_Kontrolle, timeout;
                              
                              /**
                               * Beschreibe diese Funktion …
                               */
                              function Magnetventil_Ein() {
                                if (!Magnetventil_Kontrolle && Restzeit > 0) {
                                  Magnetventil_Kontrolle = setInterval(function () {
                                    if (Restzeit > 0 && getState("sonoff.0.Aqua_Float.POWER1").val) {
                                      Restzeit = (typeof Restzeit == 'number' ? Restzeit : 0) + -1;
                                    } else {
                                      setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, false);
                                      (function () {if (Magnetventil_Kontrolle) {clearInterval(Magnetventil_Kontrolle); Magnetventil_Kontrolle = null;}})();
                                      sendTo("telegram.0", "send", {
                                          text: ('Magnetventil ist eingeschaltet')
                                      });
                                    }
                                  }, 2000);
                                  setState("sonoff.0.Aqua_Control.POWER1"/*Osmose_Magnetventil*/, true);
                                  timeout = setTimeout(function () {
                                    sendTo("telegram.0", "send", {
                                        text: ('Magnetventil ist ausgeschaltet')
                                    });
                                  }, 4000);
                                  (function () {if (timeout) {clearTimeout(timeout); timeout = null;}})();
                                }
                              }
                              
                              
                              Restzeit = 150;
                              Magnetventil_Kontrolle = null;
                              
                              on({id: 'sonoff.0.Aqua_Float.POWER1', change: "gt"}, function (obj) {
                                var value = obj.state.val;
                                var oldValue = obj.oldState.val;
                                Magnetventil_Ein();
                              });
                              schedule("0 0 * * *", function () {
                                Restzeit = 150;
                                if (getState("sonoff.0.Aqua_Float.POWER1").val) {
                                  Magnetventil_Ein();
                                }
                              });
                              
                              paul53P Offline
                              paul53P Offline
                              paul53
                              schrieb am zuletzt editiert von
                              #68

                              @Aphofis sagte:

                              falsche Variable gelöscht

                              Wieso ? Sieht doch gut aus.

                              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:

                                falsche Variable gelöscht

                                Wieso ? Sieht doch gut aus.

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

                                @paul53
                                Ja habe ich mir auch gedacht. Nur wie die zweite Variable entstanden ist keine Ahnung.
                                vllt tomatos on my eyes
                                Normal erstelle ich eine Variable nur einmal

                                paul53P 1 Antwort Letzte Antwort
                                0
                                • AphofisA Aphofis

                                  @paul53
                                  Ja habe ich mir auch gedacht. Nur wie die zweite Variable entstanden ist keine Ahnung.
                                  vllt tomatos on my eyes
                                  Normal erstelle ich eine Variable nur einmal

                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  schrieb am zuletzt editiert von paul53
                                  #70

                                  @Aphofis sagte:

                                  Normal erstelle ich eine Variable nur einmal

                                  Timer-Variablen dürfen gar nicht manuell erstellt werden ! Problem ist, dass sie erst sichtbar sind, wenn man eine andere Variable in das Fenster zieht und danach die Timer-Variable selektiert. Der Timer muss ebenfalls schon im Editorfenster vorhanden sein. Issue auf Github existiert bereits.

                                  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:

                                    Normal erstelle ich eine Variable nur einmal

                                    Timer-Variablen dürfen gar nicht manuell erstellt werden ! Problem ist, dass sie erst sichtbar sind, wenn man eine andere Variable in das Fenster zieht und danach die Timer-Variable selektiert. Der Timer muss ebenfalls schon im Editorfenster vorhanden sein. Issue auf Github existiert bereits.

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

                                    @paul53
                                    Verstehe ich nicht wie du das meinst

                                    paul53P 1 Antwort Letzte Antwort
                                    0
                                    • AphofisA Aphofis

                                      @paul53
                                      Verstehe ich nicht wie du das meinst

                                      paul53P Offline
                                      paul53P Offline
                                      paul53
                                      schrieb am zuletzt editiert von paul53
                                      #72

                                      @Aphofis
                                      Wenn ein Timer erstellt wurde, sieht man die Variable timeout nicht.
                                      Blockly_temp.JPG
                                      Erst wenn man eine andere Variable (dummy) erstellt hat, kann man z.B. setze dummy auf in das Fenster ziehen und anschließend timeout selektieren.
                                      Blockly_temp2.JPG
                                      Das Problem: Da man die Variable timeout zum in das Fenster ziehen nicht zur Auswahl hat, ist man geneigt, eine weitere Variable timeout zu erstellen.
                                      Blockly_temp.JPG

                                      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
                                      1
                                      • paul53P paul53

                                        @Aphofis
                                        Wenn ein Timer erstellt wurde, sieht man die Variable timeout nicht.
                                        Blockly_temp.JPG
                                        Erst wenn man eine andere Variable (dummy) erstellt hat, kann man z.B. setze dummy auf in das Fenster ziehen und anschließend timeout selektieren.
                                        Blockly_temp2.JPG
                                        Das Problem: Da man die Variable timeout zum in das Fenster ziehen nicht zur Auswahl hat, ist man geneigt, eine weitere Variable timeout zu erstellen.
                                        Blockly_temp.JPG

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

                                        @paul53
                                        Cool Danke für die ausführliche Erklärung! Ich werde in Zukunft aufpassen

                                        1 Antwort Letzte Antwort
                                        0
                                        • AphofisA Offline
                                          AphofisA Offline
                                          Aphofis
                                          schrieb am zuletzt editiert von
                                          #74

                                          @paul53
                                          Also mit der steuerung beim Vlies stimmt was nicht es soll ja nicht mehr als 50 cm laufen laut Zähler sollen heute 180 cm gelaufen sein.
                                          Wie kann das sein!?

                                          paul53P 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

                                          835

                                          Online

                                          32.5k

                                          Benutzer

                                          81.8k

                                          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