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. Futterautomatik

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.6k

Futterautomatik

Geplant Angeheftet Gesperrt Verschoben Blockly
15 Beiträge 3 Kommentatoren 419 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 Offline
    AphofisA Offline
    Aphofis
    schrieb am zuletzt editiert von Aphofis
    #6

    @paul53
    Ja hab ich probiert und Ja Power5 war falsch
    hab alles mal im minuten bereich getestet. es läuft.
    Hab es aber etwas anders aufgebaut.
    Also hatte die Vorlage deiner Steuerung genommen und den Faktor raus genommen für die pumpen steuerung
    dann halt Pumpe zur uhrzeit gestoppt und die Steuerung auch von dir für die Fütterung einfach den timeout auf dann 5 min gestellt und pumpe auf 20 min timeout.
    Die pumpe wird dann zB. 9:00 Uhr ausgeschaltet und nach Datenpunkt wird dann 5 min später Futter nach Faktor zu 500ms dosiert. die Pumpe springt dann 20 min nach 9 wieder an und hatte somit eine Pause von 15 min. also perfekt.
    Ob es so einwandfrei ist, weiss ich nicht zumindest gibt niemand einen Fehler aus und die Steuerung macht was sie soll.

    Pumpen Steuerung 1

    var clock, Uhrzeit, schedule1, timeout;
    
    // Beschreibe diese Funktion …
    async function Pumpe() {
      setState('sonoff.0.Aqua_Control.POWER8' /* Aqua_Control POWER8 */, false);
      console.log('Pumpe wurde ausgeschaltet');
      sendTo("telegram.0", "send", {
          text: 'Pumpe wurde ausgeschaltet'
      });
      (() => { if (timeout) { clearTimeout(timeout); timeout = null; }})();
      timeout = setTimeout(async () => {
        timeout = null;
        setState('sonoff.0.Aqua_Control.POWER8' /* Aqua_Control POWER8 */, true);
        console.log('Pumpe wurde eingeschaltet');
        sendTo("telegram.0", "send", {
            text: 'Pumpe wurde eingeschaltet'
        });
      }, 1200000);
    }
    
    // Beschreibe diese Funktion …
    async function setUhr(clock) {
      Uhrzeit = clock.split(':');
      schedule1 = schedule((Uhrzeit[1]).toString().trim() + ' ' + (Uhrzeit[0]).toString().trim() + ' ' + '*'.toString().trim() + ' ' + '*'.toString().trim() + ' ' + '*'.toString().trim(), async () => {
        await Pumpe();
      });
    }
    
    
    await setUhr(getState('0_userdata.0.Futterautomatik.Futterautomatik_Uhrzeit_1').val);
    on({ id: [].concat(['0_userdata.0.Futterautomatik.Futterautomatik_Uhrzeit_1']), change: 'ne' }, async (obj) => {
      let value = obj.state.val;
      let oldValue = obj.oldState.val;
      (() => { if (clock) { clearSchedule(clock); clock = null; }})();
      await setUhr((obj.state ? obj.state.val : ''));
    });
    

    Futter Steuerung 1

    var clock, timeout, Uhrzeit, Dauer, schedule1, Intervall;
    
    // Beschreibe diese Funktion …
    async function Futter() {
      timeout = setTimeout(async () => {
        timeout = null;
        Dauer = parseFloat(getState('0_userdata.0.Futterautomatik.Futterautomatik_Faktor_1').val);
        setState('sonoff.0.Aqua_Control.POWER5' /* Aqua_Control POWER5 */, true);
        console.log('Futter wurde dosiert');
        sendTo("telegram.0", "send", {
            text: (['Futter wurde dosiert','Futterautomat ist ',getState('sonoff.0.Aqua_Control.POWER5').val].join(''))
        });
        // Intervalldauer = Faktor
        Intervall = setInterval(async () => {
          Dauer = (typeof Dauer === 'number' ? Dauer : 0) + -1;
          if (Dauer <= 0) {
            (() => { if (Intervall) { clearInterval(Intervall); Intervall = null; }})();
            setState('sonoff.0.Aqua_Control.POWER5' /* Aqua_Control POWER5 */, false);
          }
          (() => { if (timeout) { clearTimeout(timeout); timeout = null; }})();
        }, 500);
      }, 300000);
    }
    
    // Beschreibe diese Funktion …
    async function setUhr(clock) {
      Uhrzeit = clock.split(':');
      schedule1 = schedule((Uhrzeit[1]).toString().trim() + ' ' + (Uhrzeit[0]).toString().trim() + ' ' + '*'.toString().trim() + ' ' + '*'.toString().trim() + ' ' + '*'.toString().trim(), async () => {
        await Futter();
      });
    }
    
    
    await setUhr(getState('0_userdata.0.Futterautomatik.Futterautomatik_Uhrzeit_1').val);
    on({ id: [].concat(['0_userdata.0.Futterautomatik.Futterautomatik_Uhrzeit_1']), change: 'ne' }, async (obj) => {
      let value = obj.state.val;
      let oldValue = obj.oldState.val;
      (() => { if (clock) { clearSchedule(clock); clock = null; }})();
      await setUhr((obj.state ? obj.state.val : ''));
    });
    
    paul53P 1 Antwort Letzte Antwort
    0
    • AphofisA Aphofis

      @paul53
      Ja hab ich probiert und Ja Power5 war falsch
      hab alles mal im minuten bereich getestet. es läuft.
      Hab es aber etwas anders aufgebaut.
      Also hatte die Vorlage deiner Steuerung genommen und den Faktor raus genommen für die pumpen steuerung
      dann halt Pumpe zur uhrzeit gestoppt und die Steuerung auch von dir für die Fütterung einfach den timeout auf dann 5 min gestellt und pumpe auf 20 min timeout.
      Die pumpe wird dann zB. 9:00 Uhr ausgeschaltet und nach Datenpunkt wird dann 5 min später Futter nach Faktor zu 500ms dosiert. die Pumpe springt dann 20 min nach 9 wieder an und hatte somit eine Pause von 15 min. also perfekt.
      Ob es so einwandfrei ist, weiss ich nicht zumindest gibt niemand einen Fehler aus und die Steuerung macht was sie soll.

      Pumpen Steuerung 1

      var clock, Uhrzeit, schedule1, timeout;
      
      // Beschreibe diese Funktion …
      async function Pumpe() {
        setState('sonoff.0.Aqua_Control.POWER8' /* Aqua_Control POWER8 */, false);
        console.log('Pumpe wurde ausgeschaltet');
        sendTo("telegram.0", "send", {
            text: 'Pumpe wurde ausgeschaltet'
        });
        (() => { if (timeout) { clearTimeout(timeout); timeout = null; }})();
        timeout = setTimeout(async () => {
          timeout = null;
          setState('sonoff.0.Aqua_Control.POWER8' /* Aqua_Control POWER8 */, true);
          console.log('Pumpe wurde eingeschaltet');
          sendTo("telegram.0", "send", {
              text: 'Pumpe wurde eingeschaltet'
          });
        }, 1200000);
      }
      
      // Beschreibe diese Funktion …
      async function setUhr(clock) {
        Uhrzeit = clock.split(':');
        schedule1 = schedule((Uhrzeit[1]).toString().trim() + ' ' + (Uhrzeit[0]).toString().trim() + ' ' + '*'.toString().trim() + ' ' + '*'.toString().trim() + ' ' + '*'.toString().trim(), async () => {
          await Pumpe();
        });
      }
      
      
      await setUhr(getState('0_userdata.0.Futterautomatik.Futterautomatik_Uhrzeit_1').val);
      on({ id: [].concat(['0_userdata.0.Futterautomatik.Futterautomatik_Uhrzeit_1']), change: 'ne' }, async (obj) => {
        let value = obj.state.val;
        let oldValue = obj.oldState.val;
        (() => { if (clock) { clearSchedule(clock); clock = null; }})();
        await setUhr((obj.state ? obj.state.val : ''));
      });
      

      Futter Steuerung 1

      var clock, timeout, Uhrzeit, Dauer, schedule1, Intervall;
      
      // Beschreibe diese Funktion …
      async function Futter() {
        timeout = setTimeout(async () => {
          timeout = null;
          Dauer = parseFloat(getState('0_userdata.0.Futterautomatik.Futterautomatik_Faktor_1').val);
          setState('sonoff.0.Aqua_Control.POWER5' /* Aqua_Control POWER5 */, true);
          console.log('Futter wurde dosiert');
          sendTo("telegram.0", "send", {
              text: (['Futter wurde dosiert','Futterautomat ist ',getState('sonoff.0.Aqua_Control.POWER5').val].join(''))
          });
          // Intervalldauer = Faktor
          Intervall = setInterval(async () => {
            Dauer = (typeof Dauer === 'number' ? Dauer : 0) + -1;
            if (Dauer <= 0) {
              (() => { if (Intervall) { clearInterval(Intervall); Intervall = null; }})();
              setState('sonoff.0.Aqua_Control.POWER5' /* Aqua_Control POWER5 */, false);
            }
            (() => { if (timeout) { clearTimeout(timeout); timeout = null; }})();
          }, 500);
        }, 300000);
      }
      
      // Beschreibe diese Funktion …
      async function setUhr(clock) {
        Uhrzeit = clock.split(':');
        schedule1 = schedule((Uhrzeit[1]).toString().trim() + ' ' + (Uhrzeit[0]).toString().trim() + ' ' + '*'.toString().trim() + ' ' + '*'.toString().trim() + ' ' + '*'.toString().trim(), async () => {
          await Futter();
        });
      }
      
      
      await setUhr(getState('0_userdata.0.Futterautomatik.Futterautomatik_Uhrzeit_1').val);
      on({ id: [].concat(['0_userdata.0.Futterautomatik.Futterautomatik_Uhrzeit_1']), change: 'ne' }, async (obj) => {
        let value = obj.state.val;
        let oldValue = obj.oldState.val;
        (() => { if (clock) { clearSchedule(clock); clock = null; }})();
        await setUhr((obj.state ? obj.state.val : ''));
      });
      
      paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von
      #7

      @aphofis sagte:

        (() => { if (clock) { clearSchedule(clock); clock = null; }})();
      

      In beiden Steuerungen wird die falsche Variable gestoppt! Nicht clock, sondern schedule1 muss gestoppt werden.

      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 sagte:

          (() => { if (clock) { clearSchedule(clock); clock = null; }})();
        

        In beiden Steuerungen wird die falsche Variable gestoppt! Nicht clock, sondern schedule1 muss gestoppt werden.

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

        @paul53 sagte in Futterautomatik:

        @aphofis sagte:

          (() => { if (clock) { clearSchedule(clock); clock = null; }})();
        

        In beiden Steuerungen wird die falsche Variable gestoppt! Nicht clock, sondern schedule1 muss gestoppt werden.

        also so !?

         (() => { if (schedule1) { clearSchedule(schedule1); schedule1 = null; }})();
        
        paul53P 1 Antwort Letzte Antwort
        0
        • AphofisA Aphofis

          @paul53 sagte in Futterautomatik:

          @aphofis sagte:

            (() => { if (clock) { clearSchedule(clock); clock = null; }})();
          

          In beiden Steuerungen wird die falsche Variable gestoppt! Nicht clock, sondern schedule1 muss gestoppt werden.

          also so !?

           (() => { if (schedule1) { clearSchedule(schedule1); schedule1 = null; }})();
          
          paul53P Offline
          paul53P Offline
          paul53
          schrieb am zuletzt editiert von
          #9

          @aphofis sagte: also so !?

          Ja.

          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 sagte: also so !?

            Ja.

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

            @paul53 sagte in Futterautomatik:

            @aphofis sagte: also so !?

            Ja.

            Prima besten Dank !!!

            AphofisA 1 Antwort Letzte Antwort
            0
            • AphofisA Aphofis

              @paul53 sagte in Futterautomatik:

              @aphofis sagte: also so !?

              Ja.

              Prima besten Dank !!!

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

              Leider gab es ein weiteres Problem.
              Der ESP8266 ist beim dosieren Offline gegangen und der Futterautomat stand auf true
              bis das Futter fröhlich dosiert wurde. Hatte zum Glück zum testen nur eine geringe Menge in den Automaten gepackt.
              kann man das irgendwie begrenzen, das maximal pro vorgang wirklich nur zB 300 ms der Futterautomat auf true steht oder gibt es vielleicht eine andere Idee °!°
              alive auf false bringt ja nichts. Aber vielleicht kann man das begrenzen.

              paul53P 1 Antwort Letzte Antwort
              0
              • AphofisA Aphofis

                Leider gab es ein weiteres Problem.
                Der ESP8266 ist beim dosieren Offline gegangen und der Futterautomat stand auf true
                bis das Futter fröhlich dosiert wurde. Hatte zum Glück zum testen nur eine geringe Menge in den Automaten gepackt.
                kann man das irgendwie begrenzen, das maximal pro vorgang wirklich nur zB 300 ms der Futterautomat auf true steht oder gibt es vielleicht eine andere Idee °!°
                alive auf false bringt ja nichts. Aber vielleicht kann man das begrenzen.

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

                @aphofis sagte: Der ESP8266 ist beim dosieren Offline gegangen

                Dann kann man mit ioBroker nicht mehr eingreifen. Schutzfunktionen müssten also direkt auf dem ESP implementiert werden. Davon habe ich aber keine Ahnung.

                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 2 Antworten Letzte Antwort
                0
                • paul53P paul53

                  @aphofis sagte: Der ESP8266 ist beim dosieren Offline gegangen

                  Dann kann man mit ioBroker nicht mehr eingreifen. Schutzfunktionen müssten also direkt auf dem ESP implementiert werden. Davon habe ich aber keine Ahnung.

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

                  @paul53
                  OK!
                  Ich habe Tasmota drauf. ich gucke mal ob es Konsolen befehle gibt um zB das Relais dauerhaft auf max true xxx ms setzen kann. wenn der ESP wieder online geht kann man aber das doch prüfen mit Blockly wenn das Gerät bei start also wenn eine IP ausgegeben wird dann MUSS das Relais auf false gesetzt werden außer es ist dosier Zeit.

                  AphofisA 1 Antwort Letzte Antwort
                  0
                  • AphofisA Aphofis

                    @paul53
                    OK!
                    Ich habe Tasmota drauf. ich gucke mal ob es Konsolen befehle gibt um zB das Relais dauerhaft auf max true xxx ms setzen kann. wenn der ESP wieder online geht kann man aber das doch prüfen mit Blockly wenn das Gerät bei start also wenn eine IP ausgegeben wird dann MUSS das Relais auf false gesetzt werden außer es ist dosier Zeit.

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

                    @paul53
                    jetzt sind die Geräte wieder Online nur die ip adressen werden nicht mehr angezeigt
                    es bleibt bei 0.0.0.0
                    also läuft doch nicht ganz.

                    1 Antwort Letzte Antwort
                    0
                    • paul53P paul53

                      @aphofis sagte: Der ESP8266 ist beim dosieren Offline gegangen

                      Dann kann man mit ioBroker nicht mehr eingreifen. Schutzfunktionen müssten also direkt auf dem ESP implementiert werden. Davon habe ich aber keine Ahnung.

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

                      @paul53 sagte in Futterautomatik:

                      @aphofis sagte: Der ESP8266 ist beim dosieren Offline gegangen

                      Dann kann man mit ioBroker nicht mehr eingreifen. Schutzfunktionen müssten also direkt auf dem ESP implementiert werden. Davon habe ich aber keine Ahnung.

                      Habe es jetzt mit einem Befehl geschafft. Direkt im Tasmota kann man so zu sagen eine Max ein Zeit einstellen diese habe ich jetzt für das Relais 5 auf 300 ms gesetzt. Damit pro true schaltung nicht mehr als 300ms dosiert wird. PulseTime5 3 ist alles und das funktioniert auch nach mehreren Neustarts des ESP8266

                      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

                      621

                      Online

                      32.7k

                      Benutzer

                      82.4k

                      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