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. GPIO Status Wemos d1 mini an iobroker senden

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.1k

GPIO Status Wemos d1 mini an iobroker senden

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
193 Beiträge 5 Kommentatoren 25.0k Aufrufe 5 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.
  • B Beowolf

    Das ist das aktuelle Programm:

    // Programm zur Ansteuerung eines Schrittmotors um eine kleine Schiebetür (Hühnerklappe) zu betätigen
    // Alles läuft auf einen Wemos D1 mini.
    // In Verbindung mit ioBroker ist per mqtt eine Kontrolle/Öffnen/Schliessen der Tür möglich.
    // Eine lokale Steuerung ist per Taster zu jederzeit durchführbar.
    // Endanschläge sind durch Reedkontakte ausgeführt.
    
    //*******************************************************
    // Das Programm und die vielen Änderungen sind mit der Hilfe von Forenmitgliedern aus dem ioBroker Forum entstanden (https://forum.iobroker.net).
    //
    // https://forum.iobroker.net/topic/54852/gpio-status-wemos-d1-mini-an-iobroker-senden
    //
    // Ein spezieller Dank geht an TT-Tom, Andreas-5, SBorg. Ohne  Mithilfe dieser Forenmitglieder würden die Hühner noch immer vor verschlossener Tür stehen.
    //*******************************************************
    
    
    #include <ESP8266WiFi.h>
    #include <ArduinoOTA.h>
    #include <PubSubClient.h>
    #include <AccelStepper.h>
    #include <Adafruit_NeoPixel.h>
    
    #ifndef STASSID
    #define STASSID "----"
    #define STAPSK  "---------"
    #endif
    
    #define MotorStatus D2 // Steppermotor aktivieren/deaktivieren
    #define LEDpin 3 // Umgesteuerter GPIO für die NEO-Led
    #define NUMPIXELS 1 // Anzal der LEDs
    
    const char* ssid = STASSID;
    const char* password = STAPSK;
    
    char* mqtt_client_id = "Huehnerklappe";
    const char* mqtt_server = "---";
    const int mqtt_port = --;
    const char* mqtt_user = "--";
    const char* mqtt_password = "----";
    
    const byte pinTuerAuf = D6;    // Endschalter Tür offen
    const byte pinTuerZu = D5;   // Endschalter Tür geschlossen
    const byte pinTasterAuf = D0; // Taster Tür öffnen
    const byte pinTasterZu = D7;  // Taster Tür schließen
    const byte pinTasterStopp = D1; // Taster Bewegung anhalten
    
    const long SchritteUmdrehung = 200; // Schritte des Schrittmotors für 360 Grad der Tür
    const unsigned int TuerbewegungZu =  61000;
    const unsigned int TuerbewegungAuf = -61000;
    enum ZUSTAENDE {STOP, TUERZU, OEFFNEN, TUERAUF, SCHLIESSEN};
    
    int lastEndlageAufState = 1;
    int endlageAufState = 1;
    int lastEndlageZuState = 1 ;
    int endlageZuState = 1;
    
    int lastTasterAufState = 1;
    int tasterAufState = 1;
    int lastTasterZuState = 1;
    int tasterZuState = 1;
    int lastTasterStoppState = 1;
    int tasterStoppState = 1;
    
    int richtung = 0; //  1 > Auf, 2 > Zu
    int stopzeitTuer = 10000; //Pausenzeit bis Weiterfahrt in ms
    int lebenszeichen_zaehler = 0; // Zähler um Lebenzeichen an MQTT Broker zusenden
    int lebenszeichen_interval = 10; // interval für MQTT Broker in sek
    
    long led_takt    = 500; // Zeittakt (ms) für die LED  ##takt##
    long led_zeit; // Letzter Durchlauf (ms) für die LED  ##takt##
    long lebenszeichen_takt = lebenszeichen_interval * 1000; // Zeittakt (ms)  ##takt##
    long lebenszeichen_zeit; // Letzter Durchlauf (ms)  ##takt##
    long lebenszeichen_ein_aus = 0; // ##takt##
    
    
    WiFiClient espClient;
    PubSubClient mqttClient(espClient);
    
    AccelStepper stepper(1, D3, D4);  //Pins für den Steppermotor STEP , DIR
    AccelStepper stepperauf(1, D3, D4);  //Pins für den Steppermotor STEP , DIR
    Adafruit_NeoPixel pixels = Adafruit_NeoPixel(1, LEDpin, NEO_GRB + NEO_KHZ800);
    
    void setup() {
    
      //GPIO Umsteuerung
      //GPIO 1 (TX) swap the pin to a GPIO.
      pinMode(1, FUNCTION_3);
      //GPIO 3 (RX) swap the pin to a GPIO.
      pinMode(3, FUNCTION_3);
      pinMode(LEDpin, OUTPUT); // NEO-LED
      pinMode(pinTuerAuf, INPUT_PULLUP);    // Endschalter Tür offen
      pinMode(pinTuerZu, INPUT_PULLUP);   // Endschalter Tür geschlossen
      pinMode(pinTasterAuf, INPUT_PULLUP);  // Taster Tür öffnen
      pinMode(pinTasterZu, INPUT_PULLUP); // Taster Tür schließen
      pinMode(pinTasterStopp, INPUT_PULLUP);  // Taster Bewegung anhalten
      pinMode(MotorStatus, OUTPUT); // Enable Motor 1
      pinMode(LED_BUILTIN, OUTPUT); // Board-LED nutzen
      stepper.setMaxSpeed(1000);
      stepperauf.setMaxSpeed(6000);
      stepper.setAcceleration(1500);
      stepperauf.setAcceleration(6000);
    
      Serial.begin(9600);
      //  while(!Serial){
      //    ; // wartet bis die serielle Schnittstelle eine Verbindung hergestellt hat. Wird für natives USB benötigt
      //  }
    
      // Per WLAN mit dem Netzwerk verbinden
      Serial.print("Verbinden mit ");
      Serial.println(ssid);
      WiFi.begin(ssid, password);
      while (WiFi.status() != WL_CONNECTED) {
        delay(500);
        Serial.print(".");
      }
    
      ///////////////////////////////////////////
      // Anfang Update über Wlan
      ///////////////////////////////////////////
    
      ArduinoOTA.onStart([]() {
        String type;
        if (ArduinoOTA.getCommand() == U_FLASH) {
          type = "sketch";
        } else { // U_FS
          type = "filesystem";
        }
    
        // NOTE: if updating FS this would be the place to unmount FS using FS.end()
        Serial.println("Start updating " + type);
      });
      ArduinoOTA.onEnd([]() {
        Serial.println("\nEnd");
      });
      ArduinoOTA.onProgress([](unsigned int progress, unsigned int total) {
        Serial.printf("Progress: %u%%\r", (progress / (total / 100)));
      });
      ArduinoOTA.onError([](ota_error_t error) {
        Serial.printf("Error[%u]: ", error);
        if (error == OTA_AUTH_ERROR) {
          Serial.println("Auth Failed");
        } else if (error == OTA_BEGIN_ERROR) {
          Serial.println("Begin Failed");
        } else if (error == OTA_CONNECT_ERROR) {
          Serial.println("Connect Failed");
        } else if (error == OTA_RECEIVE_ERROR) {
          Serial.println("Receive Failed");
        } else if (error == OTA_END_ERROR) {
          Serial.println("End Failed");
        }
      });
      ArduinoOTA.begin();
    
      ///////////////////////////////////////////
      // Ende Update über Wlan
      ///////////////////////////////////////////
    
      // Die IP vom Webserver auf dem seriellen Monitor ausgeben
      Serial.println("");
      Serial.println("WLAN verbunden.");
      Serial.println("IP Adresse: ");
      Serial.println(WiFi.localIP());
    
      // MQTT Brocker
      // Mit ioBroker Mqtt verbinden
      mqttClient.setServer(mqtt_server, mqtt_port);//MQTT Server, - Port
      mqttClient.setCallback(callback);
    
      // NEO_Pixel Start
      pixels.begin(); // This initializes the NeoPixel library.
    
      lebenszeichen_zeit = millis(); // ##takt##
      led_zeit = millis(); // ##takt##
      
      Serial.println("Programmanfang");
    }
    
    //ende Setup
    //////////////////////////////////////////////////////////////////////////////////
    
    void loop() {
    
      lebenszeichen();
    
      ArduinoOTA.handle();
      ArduinoOTA.setHostname("Huehnerklappe");
    
      stepper.run();
      stepperauf.run();
    
      tasterStoppState = digitalRead(pinTasterStopp); // Taster STOP bzw Lichtschranke
      endlageAufState = digitalRead(pinTuerAuf); 	  // Endlage AUF
      endlageZuState = digitalRead(pinTuerZu); 		  // Endlage ZU
      tasterAufState = digitalRead(pinTasterAuf); 	  // Taster AUF
      tasterZuState = digitalRead(pinTasterZu); 	  // Taster ZU
    
      // Hardwaretasten
      // Ich gehe davon aus, dass der Motor so lange laufen soll, wie die Taste festgehalten wird.
      // Wird die Taste losgelassen soll gestoppt werden.
      // 
      // Wird die Klappe über ioBroker/MQTT gesteuert, müssen da ja eigene Variablen her, damit sich das nicht
      // vermischt.
      // Dann würde ich aber genau dieses Vorgehen hier nutzen, aber die tasterAufState und tasterZuState aus den
      // beiden Möglichkeiten, Hardwaretaster und ioBroker/MQTT erzeugen.
      // Dabei muss dann ein wenig Sicherheit mit rein, z.B. wenn einer von beiden Zuständen wieder auf "Stopp" geht
      // sollte gestoppt werden, auch wenn der andere noch auf fahren steht. Beispiel: ioBroker fährt die Klappe zu, 
      // jemand steht daneben und sieht, das etwas nicht stimmt, dann braucht er nur auf die TAste drücken und loslassen,
      // dann stoppt die Tür. Das kann man natürlich noch weiter spinnen, so dass zuum stoppen egal ist, welche Taste 
      // gerade gedrückt wird. (Na, jetzt schweife ich schon wieder ab!) ;-)
      
      if (tasterStoppState != lastTasterStoppState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
        // Stoptaster und Richtung Zu löst Halt aus
        if ((tasterStoppState == LOW) && (richtung == 2)) {
          Serial.println("Taster Stop LOW");
          TuerSteuerung(STOP);
        } else {
          Serial.println("Taster Stop High"); // Lichtschranke wieder frei
          if (richtung == 2) // Nur dann, wenn vorher auch schon SCHLIESSEN aktiv war, hier weiter fahren, wenn Lichtschranke frei.
            TuerSteuerung(SCHLIESSEN);
        }
      }
      else if (endlageAufState != lastEndlageAufState) { // Abfrage damit nicht bei jedem Durchlauf die Endlage neu gesetzt wird, sondern nur bei Änderung
        if (endlageAufState == LOW) {
          TuerEndlagen(TUERAUF);
        }
      }
      else if (endlageZuState != lastEndlageZuState) { // Abfrage damit nicht bei jedem Durchlauf die Endlage neu gesetzt wird, sondern nur bei Änderung
        if (endlageZuState == LOW) {
          TuerEndlagen(TUERZU);
        }
      }
      else if (tasterAufState != lastTasterAufState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
        if (tasterAufState == LOW && endlageAufState != LOW) { // Hier würde ich auf jeden Fall die Endlage mit einbeziehen, da ansonsten der Motor zumindest startet.
          Serial.println("Taster AUF");
          TuerSteuerung(OEFFNEN);
        } else {                                          // Und auch beim loslassen stoppen.
          Serial.println("Taster AUF losgelassen");
          TuerSteuerung(STOP);
        }
      }
      else if (tasterZuState != lastTasterZuState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
        if (tasterZuState == LOW && endlageZuState != LOW) { // Hier würde ich auf jeden Fall die Endlage mit einbeziehen, da ansonsten der Motor zumindest startet.
          Serial.println("Taster ZU");
          TuerSteuerung(SCHLIESSEN);
        } else {                                          // Und auch beim loslassen stoppen.   
          Serial.println("Taster ZU losgelassen");
          TuerSteuerung(STOP);
        }
      }
    
      lastTasterStoppState = tasterStoppState;
      lastEndlageAufState  = endlageAufState;
      lastEndlageZuState   = endlageZuState;
      lastTasterAufState   = tasterAufState;
      lastTasterZuState    = tasterZuState;
    
    
      // MQTT Broker
      mqttClient.loop();
      if (!mqttClient.connected()) {
        reconnectToMQTT();
      }
    
    
    }
    
    //ende loop
    /////////////////////////////////////////////////////////////////////////////////
    
    
    long pos(int winkel) {
      return (winkel * SchritteUmdrehung / 360L);
    }
    
    
    
    // Endlagen Steuerung
    void TuerEndlagen(byte zustand) {
    
      stopp();
      richtung = 0;
      Serial.println("Motor angehalten - Endlage erreicht");
    
      switch (zustand) {
    
        // Tür ist offen
    
        case TUERAUF:
          Serial.println("Tuer geoeffnet");
          pixels.setPixelColor(0, pixels.Color(255, 0, 0)); //LED Farbe rot
          pixels.show();
          // Schaltzustände übermitteln
          mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "1");
          mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "0");
    
          break;
    
        // Tür ist geschlossen
    
        case TUERZU:
          Serial.println("Tuer geschlossen");
          pixels.setPixelColor(0, pixels.Color(0, 255, 0)); //LED Farbe grün
          pixels.show();
          // Schaltzustände übermitteln
          mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "1");
          break;
    
      }
    }
    
    
    /// Tuer / Motorsteuerung
    void TuerSteuerung(byte zustand) {
    
      // stopp();
      Serial.println("Neuer Fahrbefehl");
    
      digitalWrite(MotorStatus, LOW);  //Motor aktiviert
    
      switch (zustand) {
    
        // Manuelle Steuerung
    
        case STOP:
          stopp();
          Serial.println("Motor angehalten");
          pixels.setPixelColor(0, pixels.Color(255, 255, 255)); //LED Farbe weiss
          pixels.show();
          delay(stopzeitTuer);
          Serial.println("Pausenzeit abgelaufen");
    
          break;
    
        // Tür wird geöffnet
    
        case OEFFNEN:
          richtung = 1;
          if (digitalRead(pinTuerAuf)) {
            stepperauf.move(pos(TuerbewegungAuf));
            Serial.print("Tuer oeffnet ... ");
            pixels.setPixelColor(0, pixels.Color(0, 0, 255)); //LED Farbe blau
            pixels.show();
            // Schaltzustände übermitteln
            mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "1");
            mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "0");
            mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "0");
            mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "0");
          }
          break;
    
    
        // Tür wir geschlossen
    
        case SCHLIESSEN:
          richtung = 2;
          if ((digitalRead(pinTuerZu)) && (digitalRead(pinTasterStopp))) {
            stepper.move(pos(TuerbewegungZu));
            Serial.print("Tuer schliesst ... ");
            pixels.setPixelColor(0, pixels.Color(0, 0, 255)); //LED Farbe blau
            pixels.show();
            // Schaltzustände übermitteln
            mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "0");
            mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "0");
            mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "1");
            mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "0");
          }
          break;
      }
    }
    
    
    void stopp() {
      stepper.stop();
      digitalWrite(MotorStatus, HIGH); //Motor deaktiviert
    }
    
    
    
    // MQTT Funktion
    // *************
    void reconnectToMQTT() {
    
      if (mqttClient.connect(mqtt_client_id , mqtt_user, mqtt_password)) {
        Serial.println("Per MQTT mit ioBroker verbunden");
    
        mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "0");
        mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "0");
        mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "0");
        mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "0");
        mqttClient.publish("Huehnertuer/Innen/alive", "0");
    
        mqttClient.subscribe("Huehnertuer/Innen/Tuer");
      } else {
        Serial.print("mqtt-Verbindung fehlgeschlagen ");
        Serial.print(mqttClient.state());
        Serial.println(" versuchen es in 5 Sekunden erneut");
        // Wait 5 seconds before retrying
        delay(5000);
      }
    }
    
    
    // MQTT Callback
    void callback(char* topic, byte* payload, unsigned int length)
    {
    
      payload[length] = '\0';
      String strTopic = String(topic);
      String strPayload = String((char * ) payload);
    
      Serial.print("Nachricht angekommen [");
      Serial.print(strTopic);
      Serial.print("----");
      Serial.print(strPayload);
      Serial.print("] ");
      Serial.println();
    
    
      if (strTopic == "Huehnertuer/Innen/Tuer")
      {
        // Tuer schliessen
        if (strPayload == "false") {
          Serial.println("Tuer schliesst über IoBroker");
          TuerSteuerung(SCHLIESSEN);
        }
    
        // Tuer öffnen
        if (strPayload == "true") {
          Serial.println("Tuer oeffnet über IoBroker");
          TuerSteuerung(OEFFNEN);
        }
      }
    }
    
    void lebenszeichen() {
    	
    	// ##takt## -->	
    	long current_time = millis();
    	// LED auf dem Board blinken lassen
    	if (led_zeit <= current_time) {
    		if (digitalRead(LED_BUILTIN) == HIGH)
    			digitalWrite(LED_BUILTIN, LOW);
    		else
    			digitalWrite(LED_BUILTIN, HIGH);
    		while (led_zeit <= current_time)
    			led_zeit += led_takt;
    	}
      
    	if (lebenszeichen_zeit <= current_time) {
    		if (lebenszeichen_ein_aus == 0) {
    			mqttClient.publish("Huehnertuer/Innen/alive", "1");
    			lebenszeichen_ein_aus = 1;
    		} else {
    			mqttClient.publish("Huehnertuer/Innen/alive", "0");
    			lebenszeichen_ein_aus = 0;
    		}
    		while (lebenszeichen_zeit <= current_time)
    			lebenszeichen_zeit += lebenszeichen_takt;
    	}
    	// ##takt## <--	
    }
    

    Mqtt über ioBroker geht.

    Tastensteuerung nicht wirklich.

    Drücke und halte ich z.B. die Taste für ZU, fährt die Tür auch zu. Lasse ich die Taste loß bleibt die Tür stehen und ich kann sie nicht weiter schliessen.

    Auch wird die LED weiß wenn ich die Taste loslasse.

    Es würde reichen, wenn durch Tastendruck die Tür auf bzw. zu fährt.

    Grüße
    Manfred

    T Offline
    T Offline
    TT-Tom
    schrieb am zuletzt editiert von TT-Tom
    #130

    @beowolf sagte in GPIO Status Wemos d1 mini an iobroker senden:

    Das ist das aktuelle Programm:

    Drücke und halte ich z.B. die Taste für ZU, fährt die Tür auch zu. Lasse ich die Taste loß bleibt die Tür stehen und ich kann sie nicht weiter schliessen.

    Auch wird die LED weiß

    Hi in dem Moment wo du die Taste loslässt wird die Pause von 10sek gestartet. Danach kannst du weiterfahren. Werde das umschreiben und reinstellen.

    So jetzt kannst du nach dem Loslassen gleich weiterfahren, wenn du das nicht möchtest, die Zeile bei Auf und Zu Taster auskommentieren.

      TuerSteuerung(STOP_TASTER); 
    
    // Programm zur Ansteuerung eines Schrittmotors um eine kleine Schiebetür (Hühnerklappe) zu betätigen
    // Alles läuft auf einen Wemos D1 mini.
    // In Verbindung mit ioBroker ist per mqtt eine Kontrolle/Öffnen/Schliessen der Tür möglich.
    // Eine lokale Steuerung ist per Taster zu jederzeit durchführbar.
    // Endanschläge sind durch Reedkontakte ausgeführt.
    
    //*******************************************************
    // Das Programm und die vielen Änderungen sind mit der Hilfe von Forenmitgliedern aus dem ioBroker Forum entstanden (https://forum.iobroker.net).
    //
    // https://forum.iobroker.net/topic/54852/gpio-status-wemos-d1-mini-an-iobroker-senden
    //
    // Ein spezieller Dank geht an TT-Tom, Andreas-5, SBorg. Ohne  Mithilfe dieser Forenmitglieder würden die Hühner noch immer vor verschlossener Tür stehen.
    //*******************************************************
    
    
    #include <ESP8266WiFi.h>
    #include <ArduinoOTA.h>
    #include <PubSubClient.h>
    #include <AccelStepper.h>
    #include <Adafruit_NeoPixel.h>
    
    #ifndef STASSID
    #define STASSID "TomTom24"
    #define STAPSK  "Kj1fQv7u"
    #endif
    
    #define MotorStatus D2 // Steppermotor aktivieren/deaktivieren
    #define LEDpin 3 // Umgesteuerter GPIO für die NEO-Led
    #define NUMPIXELS 1 // Anzal der LEDs
    
    const char* ssid = STASSID;
    const char* password = STAPSK;
    
    char* mqtt_client_id = "Huehnerklappe";
    const char* mqtt_server = "192.168.178.120";
    const int mqtt_port = 1883;
    const char* mqtt_user = "";
    const char* mqtt_password = "";
    
    const byte pinTuerAuf = D6;    // Endschalter Tür offen
    const byte pinTuerZu = D5;   // Endschalter Tür geschlossen
    const byte pinTasterAuf = D0; // Taster Tür öffnen
    const byte pinTasterZu = D7;  // Taster Tür schließen
    const byte pinTasterStopp = D1; // Taster Bewegung anhalten
    
    const long SchritteUmdrehung = 200; // Schritte des Schrittmotors für 360 Grad der Tür
    const unsigned int TuerbewegungZu =  61000;
    const unsigned int TuerbewegungAuf = -61000;
    enum ZUSTAENDE {STOP_LICHTSCHRANKE, STOP_TASTER, TUERZU, OEFFNEN, TUERAUF, SCHLIESSEN};
    
    int lastEndlageAufState = 1;
    int endlageAufState = 1;
    int lastEndlageZuState = 1 ;
    int endlageZuState = 1;
    
    int lastTasterAufState = 1;
    int tasterAufState = 1;
    int lastTasterZuState = 1;
    int tasterZuState = 1;
    int lastTasterStoppState = 1;
    int tasterStoppState = 1;
    
    int richtung = 0; //  1 > Auf, 2 > Zu
    int stopzeitTuer = 10000; //Pausenzeit bis Weiterfahrt in ms
    int lebenszeichen_zaehler = 0; // Zähler um Lebenzeichen an MQTT Broker zusenden
    int lebenszeichen_interval = 10; // interval für MQTT Broker in sek
    
    long led_takt    = 500; // Zeittakt (ms) für die LED  ##takt##
    long led_zeit; // Letzter Durchlauf (ms) für die LED  ##takt##
    long lebenszeichen_takt = lebenszeichen_interval * 1000; // Zeittakt (ms)  ##takt##
    long lebenszeichen_zeit; // Letzter Durchlauf (ms)  ##takt##
    long lebenszeichen_ein_aus = 0; // ##takt##
    
    
    WiFiClient espClient;
    PubSubClient mqttClient(espClient);
    
    AccelStepper stepper(1, D3, D4);  //Pins für den Steppermotor STEP , DIR
    AccelStepper stepperauf(1, D3, D4);  //Pins für den Steppermotor STEP , DIR
    Adafruit_NeoPixel pixels = Adafruit_NeoPixel(1, LEDpin, NEO_GRB + NEO_KHZ800);
    
    void setup() {
    
      //GPIO Umsteuerung
      //GPIO 1 (TX) swap the pin to a GPIO.
      pinMode(1, FUNCTION_3);
      //GPIO 3 (RX) swap the pin to a GPIO.
      pinMode(3, FUNCTION_3);
      pinMode(LEDpin, OUTPUT); // NEO-LED
      pinMode(pinTuerAuf, INPUT_PULLUP);    // Endschalter Tür offen
      pinMode(pinTuerZu, INPUT_PULLUP);   // Endschalter Tür geschlossen
      pinMode(pinTasterAuf, INPUT_PULLUP);  // Taster Tür öffnen
      pinMode(pinTasterZu, INPUT_PULLUP); // Taster Tür schließen
      pinMode(pinTasterStopp, INPUT_PULLUP);  // Taster Bewegung anhalten
      pinMode(MotorStatus, OUTPUT); // Enable Motor 1
      pinMode(LED_BUILTIN, OUTPUT); // Board-LED nutzen
      stepper.setMaxSpeed(1000);
      stepperauf.setMaxSpeed(6000);
      stepper.setAcceleration(1500);
      stepperauf.setAcceleration(6000);
    
      Serial.begin(9600);
      //  while(!Serial){
      //    ; // wartet bis die serielle Schnittstelle eine Verbindung hergestellt hat. Wird für natives USB benötigt
      //  }
    
      // Per WLAN mit dem Netzwerk verbinden
      Serial.print("Verbinden mit ");
      Serial.println(ssid);
      WiFi.begin(ssid, password);
      while (WiFi.status() != WL_CONNECTED) {
        delay(500);
        Serial.print(".");
      }
    
      ///////////////////////////////////////////
      // Anfang Update über Wlan
      ///////////////////////////////////////////
    
      ArduinoOTA.onStart([]() {
        String type;
        if (ArduinoOTA.getCommand() == U_FLASH) {
          type = "sketch";
        } else { // U_FS
          type = "filesystem";
        }
    
        // NOTE: if updating FS this would be the place to unmount FS using FS.end()
        Serial.println("Start updating " + type);
      });
      ArduinoOTA.onEnd([]() {
        Serial.println("\nEnd");
      });
      ArduinoOTA.onProgress([](unsigned int progress, unsigned int total) {
        Serial.printf("Progress: %u%%\r", (progress / (total / 100)));
      });
      ArduinoOTA.onError([](ota_error_t error) {
        Serial.printf("Error[%u]: ", error);
        if (error == OTA_AUTH_ERROR) {
          Serial.println("Auth Failed");
        } else if (error == OTA_BEGIN_ERROR) {
          Serial.println("Begin Failed");
        } else if (error == OTA_CONNECT_ERROR) {
          Serial.println("Connect Failed");
        } else if (error == OTA_RECEIVE_ERROR) {
          Serial.println("Receive Failed");
        } else if (error == OTA_END_ERROR) {
          Serial.println("End Failed");
        }
      });
      ArduinoOTA.begin();
    
      ///////////////////////////////////////////
      // Ende Update über Wlan
      ///////////////////////////////////////////
    
      // Die IP vom Webserver auf dem seriellen Monitor ausgeben
      Serial.println("");
      Serial.println("WLAN verbunden.");
      Serial.println("IP Adresse: ");
      Serial.println(WiFi.localIP());
    
      // MQTT Brocker
      // Mit ioBroker Mqtt verbinden
      mqttClient.setServer(mqtt_server, mqtt_port);//MQTT Server, - Port
      mqttClient.setCallback(callback);
    
      // NEO_Pixel Start
      pixels.begin(); // This initializes the NeoPixel library.
    
      lebenszeichen_zeit = millis(); // ##takt##
      led_zeit = millis(); // ##takt##
      
      Serial.println("Programmanfang");
    }
    
    //ende Setup
    //////////////////////////////////////////////////////////////////////////////////
    
    void loop() {
    
      lebenszeichen();
    
      ArduinoOTA.handle();
      ArduinoOTA.setHostname("Huehnerklappe");
    
      stepper.run();
      stepperauf.run();
    
      tasterStoppState = digitalRead(pinTasterStopp); // Taster STOP bzw Lichtschranke
      endlageAufState = digitalRead(pinTuerAuf);     // Endlage AUF
      endlageZuState = digitalRead(pinTuerZu);      // Endlage ZU
      tasterAufState = digitalRead(pinTasterAuf);     // Taster AUF
      tasterZuState = digitalRead(pinTasterZu);     // Taster ZU
    
      // Hardwaretasten
      // Ich gehe davon aus, dass der Motor so lange laufen soll, wie die Taste festgehalten wird.
      // Wird die Taste losgelassen soll gestoppt werden.
      // 
      // Wird die Klappe über ioBroker/MQTT gesteuert, müssen da ja eigene Variablen her, damit sich das nicht
      // vermischt.
      // Dann würde ich aber genau dieses Vorgehen hier nutzen, aber die tasterAufState und tasterZuState aus den
      // beiden Möglichkeiten, Hardwaretaster und ioBroker/MQTT erzeugen.
      // Dabei muss dann ein wenig Sicherheit mit rein, z.B. wenn einer von beiden Zuständen wieder auf "Stopp" geht
      // sollte gestoppt werden, auch wenn der andere noch auf fahren steht. Beispiel: ioBroker fährt die Klappe zu, 
      // jemand steht daneben und sieht, das etwas nicht stimmt, dann braucht er nur auf die TAste drücken und loslassen,
      // dann stoppt die Tür. Das kann man natürlich noch weiter spinnen, so dass zuum stoppen egal ist, welche Taste 
      // gerade gedrückt wird. (Na, jetzt schweife ich schon wieder ab!) ;-)
      
      if (tasterStoppState != lastTasterStoppState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
        // Stoptaster und Richtung Zu löst Halt aus
        if ((tasterStoppState == LOW) && (richtung == 2)) {
          Serial.println("Taster Stop / Lichtschranke LOW");
          TuerSteuerung(STOP_LICHTSCHRANKE);
        } else {
          Serial.println("Taster Stop / Lichtschranke High"); // Lichtschranke wieder frei
          if (richtung == 2) // Nur dann, wenn vorher auch schon SCHLIESSEN aktiv war, hier weiter fahren, wenn Lichtschranke frei.
            TuerSteuerung(SCHLIESSEN);
        }
      }
      else if (endlageAufState != lastEndlageAufState) { // Abfrage damit nicht bei jedem Durchlauf die Endlage neu gesetzt wird, sondern nur bei Änderung
        if (endlageAufState == LOW) {
          TuerEndlagen(TUERAUF);
        }
      }
      else if (endlageZuState != lastEndlageZuState) { // Abfrage damit nicht bei jedem Durchlauf die Endlage neu gesetzt wird, sondern nur bei Änderung
        if (endlageZuState == LOW) {
          TuerEndlagen(TUERZU);
        }
      }
      else if (tasterAufState != lastTasterAufState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
        if (tasterAufState == LOW && endlageAufState != LOW) { // Hier würde ich auf jeden Fall die Endlage mit einbeziehen, da ansonsten der Motor zumindest startet.
          Serial.println("Taster AUF");
          TuerSteuerung(OEFFNEN);
        } else {                                          // Und auch beim loslassen stoppen.
          Serial.println("Taster AUF losgelassen");
          TuerSteuerung(STOP_TASTER);
        }
      }
      else if (tasterZuState != lastTasterZuState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
        if (tasterZuState == LOW && endlageZuState != LOW) { // Hier würde ich auf jeden Fall die Endlage mit einbeziehen, da ansonsten der Motor zumindest startet.
          Serial.println("Taster ZU");
          TuerSteuerung(SCHLIESSEN);
        } else {                                          // Und auch beim loslassen stoppen.   
          Serial.println("Taster ZU losgelassen");
          TuerSteuerung(STOP_TASTER);
        }
      }
    
      lastTasterStoppState = tasterStoppState;
      lastEndlageAufState  = endlageAufState;
      lastEndlageZuState   = endlageZuState;
      lastTasterAufState   = tasterAufState;
      lastTasterZuState    = tasterZuState;
    
    
      // MQTT Broker
      mqttClient.loop();
      if (!mqttClient.connected()) {
        reconnectToMQTT();
      }
    
    
    }
    
    //ende loop
    /////////////////////////////////////////////////////////////////////////////////
    
    
    long pos(int winkel) {
      return (winkel * SchritteUmdrehung / 360L);
    }
    
    
    
    // Endlagen Steuerung
    void TuerEndlagen(byte zustand) {
    
      stopp();
      richtung = 0;
      Serial.println("Motor angehalten - Endlage erreicht");
    
      switch (zustand) {
    
        // Tür ist offen
    
        case TUERAUF:
          Serial.println("Tuer geoeffnet");
          pixels.setPixelColor(0, pixels.Color(255, 0, 0)); //LED Farbe rot
          pixels.show();
          // Schaltzustände übermitteln
          mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "1");
          mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "0");
    
          break;
    
        // Tür ist geschlossen
    
        case TUERZU:
          Serial.println("Tuer geschlossen");
          pixels.setPixelColor(0, pixels.Color(0, 255, 0)); //LED Farbe grün
          pixels.show();
          // Schaltzustände übermitteln
          mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "0");
          mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "1");
          break;
    
      }
    }
    
    
    /// Tuer / Motorsteuerung
    void TuerSteuerung(byte zustand) {
    
    
      Serial.println("Neuer Fahrbefehl");
    
      digitalWrite(MotorStatus, LOW);  //Motor aktiviert
    
      switch (zustand) {
    
        // Manuelle Steuerung
        
        case STOP_TASTER:
          stopp();
          richtung = 0;
          Serial.println("Motor angehalten über Taster");
          pixels.setPixelColor(0, pixels.Color(255, 255, 255)); //LED Farbe weiss
          pixels.show();
          break;
    
        case STOP_LICHTSCHRANKE:
          stopp();
          Serial.println("Motor angehalten über Lichtschranke");
          pixels.setPixelColor(0, pixels.Color(255, 255, 255)); //LED Farbe weiss
          pixels.show();
          delay(stopzeitTuer);
          Serial.println("Pausenzeit abgelaufen");
          break;
    
        // Tür wird geöffnet
    
        case OEFFNEN:
          richtung = 1;
          if (digitalRead(pinTuerAuf)) {
            stepperauf.move(pos(TuerbewegungAuf));
            Serial.print("Tuer oeffnet ... ");
            pixels.setPixelColor(0, pixels.Color(0, 0, 255)); //LED Farbe blau
            pixels.show();
            // Schaltzustände übermitteln
            mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "1");
            mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "0");
            mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "0");
            mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "0");
          }
          break;
    
    
        // Tür wir geschlossen
    
        case SCHLIESSEN:
          richtung = 2;
          if ((digitalRead(pinTuerZu)) && (digitalRead(pinTasterStopp))) {
            stepper.move(pos(TuerbewegungZu));
            Serial.print("Tuer schliesst ... ");
            pixels.setPixelColor(0, pixels.Color(0, 0, 255)); //LED Farbe blau
            pixels.show();
            // Schaltzustände übermitteln
            mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "0");
            mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "0");
            mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "1");
            mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "0");
          }
          break;
      }
    }
    
    
    void stopp() {
      stepper.stop();
      digitalWrite(MotorStatus, HIGH); //Motor deaktiviert
    }
    
    
    
    // MQTT Funktion
    // *************
    void reconnectToMQTT() {
    
      if (mqttClient.connect(mqtt_client_id , mqtt_user, mqtt_password)) {
        Serial.println("Per MQTT mit ioBroker verbunden");
    
        mqttClient.publish("Huehnertuer/Innen/Tuer_oeffnet", "0");
        mqttClient.publish("Huehnertuer/Innen/Tuer_auf", "0");
        mqttClient.publish("Huehnertuer/Innen/Tuer_schliesst", "0");
        mqttClient.publish("Huehnertuer/Innen/Tuer_zu", "0");
        mqttClient.publish("Huehnertuer/Innen/alive", "0");
    
        mqttClient.subscribe("Huehnertuer/Innen/Tuer");
      } else {
        Serial.print("mqtt-Verbindung fehlgeschlagen ");
        Serial.print(mqttClient.state());
        Serial.println(" versuchen es in 5 Sekunden erneut");
        // Wait 5 seconds before retrying
        delay(5000);
      }
    }
    
    
    // MQTT Callback
    void callback(char* topic, byte* payload, unsigned int length)
    {
    
      payload[length] = '\0';
      String strTopic = String(topic);
      String strPayload = String((char * ) payload);
    
      Serial.print("Nachricht angekommen [");
      Serial.print(strTopic);
      Serial.print("----");
      Serial.print(strPayload);
      Serial.print("] ");
      Serial.println();
    
    
      if (strTopic == "Huehnertuer/Innen/Tuer")
      {
        // Tuer schliessen
        if (strPayload == "false") {
          Serial.println("Tuer schliesst über IoBroker");
          TuerSteuerung(SCHLIESSEN);
        }
    
        // Tuer öffnen
        if (strPayload == "true") {
          Serial.println("Tuer oeffnet über IoBroker");
          TuerSteuerung(OEFFNEN);
        }
      }
    }
    
    void lebenszeichen() {
      
      // ##takt## --> 
      long current_time = millis();
      // LED auf dem Board blinken lassen
      if (led_zeit <= current_time) {
        if (digitalRead(LED_BUILTIN) == HIGH)
          digitalWrite(LED_BUILTIN, LOW);
        else
          digitalWrite(LED_BUILTIN, HIGH);
        while (led_zeit <= current_time)
          led_zeit += led_takt;
      }
      
      if (lebenszeichen_zeit <= current_time) {
        if (lebenszeichen_ein_aus == 0) {
          mqttClient.publish("Huehnertuer/Innen/alive", "1");
          lebenszeichen_ein_aus = 1;
        } else {
          mqttClient.publish("Huehnertuer/Innen/alive", "0");
          lebenszeichen_ein_aus = 0;
        }
        while (lebenszeichen_zeit <= current_time)
          lebenszeichen_zeit += lebenszeichen_takt;
      }
      // ##takt## <-- 
    }
    

    Gruß Tom
    https://github.com/tt-tom17
    Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

    NSPanel Script Wiki
    https://github.com/joBr99/nspanel-lovelace-ui/wiki

    NSPanel Adapter Wiki
    https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

    1 Antwort Letzte Antwort
    0
    • T TT-Tom

      @beowolf sagte in GPIO Status Wemos d1 mini an iobroker senden:

      @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

      @beowolf

      hast du jeden einzeln Eingang mit einem Widerstand (10k) auf 3,3,V gezogen?

      nö. Das ist doch mit "INPUT_PULLUP" erledigt, oder?

      Wie ich dir schon geschrieben hatte, habe ich auf meinem Testbrett die Taster mit den zusätzlichen Widerständen versehen. Danach ging der Fahrbefehl auch nur einmal raus Richtung auf. Wenn das mit der Anpassung von @Andreas-5 jetzt funktioniert, okay. Wie gesagt man kann nur lernen hier.
      Ich würde das sonst nochmal probieren.

      Werde den Code heute Abend mal bei mir laufen lassen. Danke für die Hilfe Andreas.

      @Andreas-5 Was hast du für Erfahrungen mit dem Befehl INPUT_PULLUP gemacht?

      AndreiosA Offline
      AndreiosA Offline
      Andreios
      Forum Testing
      schrieb am zuletzt editiert von
      #131

      @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

      @Andreas-5 Was hast du für Erfahrungen mit dem Befehl INPUT_PULLUP gemacht?

      Nein, den habe ich bisher nicht genutzt.
      Allerdings habe ich bisher auch keine Anwendung mit Tastern, nur automatisch laufende mit Sensoren.

      Schöne Grüße
      Andreas

      ioBroker auf Raspberry 4 mit SSD. Homematik IP mit CCU 3. Shelly. MySQL. Arduino. ...

      Meine Posts sind subjektiv und manipulativ, erheben Anspruch auf Allwissenheit und können Spuren von Ironie oder Sarkasmus enthalten. ;-)

      T 1 Antwort Letzte Antwort
      0
      • AndreiosA Andreios

        @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

        @Andreas-5 Was hast du für Erfahrungen mit dem Befehl INPUT_PULLUP gemacht?

        Nein, den habe ich bisher nicht genutzt.
        Allerdings habe ich bisher auch keine Anwendung mit Tastern, nur automatisch laufende mit Sensoren.

        T Offline
        T Offline
        TT-Tom
        schrieb am zuletzt editiert von TT-Tom
        #132

        @andreas-5
        okay, ich ja auch nicht habe immer externe Widerstände genutzt.

        Hast du noch eine Idee zum MQTT-Problem?

        @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

        Gruß Tom
        https://github.com/tt-tom17
        Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

        NSPanel Script Wiki
        https://github.com/joBr99/nspanel-lovelace-ui/wiki

        NSPanel Adapter Wiki
        https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

        B 1 Antwort Letzte Antwort
        0
        • T TT-Tom

          @Andreas-5

          Wie kann man verhindern, das nach einem Neustart des WEMOS der alte Fahrbefehl vom mqtt ignoriert wird. Das gleiche Problem wird auch auftreten, wenn er die Verbindung zum mqtt-Broker verliert. hast du da eine Idee.

          AndreiosA Offline
          AndreiosA Offline
          Andreios
          Forum Testing
          schrieb am zuletzt editiert von Andreios
          #133

          @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

          @Andreas-5

          Wie kann man verhindern, das nach einem Neustart des WEMOS der alte Fahrbefehl vom mqtt ignoriert wird. Das gleiche Problem wird auch auftreten, wenn er die Verbindung zum mqtt-Broker verliert. hast du da eine Idee.

          Zum Einen müsste der MQTT-Server dem Subscriber die letzten Befehle/Status senden. Das ist eine Einstellungssache, aber vielleicht ist das ja schon so eingestellt.

          Dann müsste der Statusmerker undefiniert sein, also z.B. -1, aktuell sind die auf 1:

          int lastTasterAufState = 1;
          int tasterAufState = 1;
          int lastTasterZuState = 1;
          int tasterZuState = 1;
          int lastTasterStoppState = 1;
          int tasterStoppState = 1;
          
          

          Wahrscheinlich, um den "normalen" Status 0 nach dem Start mit zu bekommen.
          Wenn die auf einem nicht gültigen Wert stehen, wird auf jeden Fall einmal der Status erwischt.
          Aber ACHTUNG: So wie ich das mit den Abfragen umgestellt habe, um die Prio hinein zu bringen funktioniert das nicht, weil am Ende alle Merker gesetzt werden und durch die else if nur immer einer pro Zyklus bearbeitet wird.
          In dem Fall würde ich das Setzen der Merker jeweils an das Ende jedes if-Block setzen:

            if (tasterStoppState != lastTasterStoppState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
              // Stoptaster und Richtung Zu löst Halt aus
              if ((tasterStoppState == LOW) && (richtung == 2)) {
                Serial.println("Taster Stop LOW");
                TuerSteuerung(STOP);
              } else {
                Serial.println("Taster Stop High"); // Lichtschranke wieder frei
                if (richtung == 2) // Nur dann, wenn vorher auch schon SCHLIESSEN aktiv war, hier weiter fahren, wenn Lichtschranke frei.
                  TuerSteuerung(SCHLIESSEN);
              }
              lastTasterStoppState = tasterStoppState;
            }
            else if (endlageAufState != lastEndlageAufState) { // Abfrage damit nicht bei jedem Durchlauf die Endlage neu gesetzt wird, sondern nur bei Änderung
              if (endlageAufState == LOW) {
                TuerEndlagen(TUERAUF);
              }
            }
            else if (endlageZuState != lastEndlageZuState) { // Abfrage damit nicht bei jedem Durchlauf die Endlage neu gesetzt wird, sondern nur bei Änderung
              if (endlageZuState == LOW) {
                TuerEndlagen(TUERZU);
              }
              lastEndlageAufState  = endlageAufState;
              lastEndlageZuState   = endlageZuState;
            }
            else if (tasterAufState != lastTasterAufState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
              if (tasterAufState == LOW && endlageAufState != LOW) { // Hier würde ich auf jeden Fall die Endlage mit einbeziehen, da ansonsten der Motor zumindest startet.
                Serial.println("Taster AUF");
                TuerSteuerung(OEFFNEN);
              } else {                                          // Und auch beim loslassen stoppen.
                Serial.println("Taster AUF losgelassen");
                TuerSteuerung(STOP);
              }
              lastTasterAufState   = tasterAufState;
            }
            else if (tasterZuState != lastTasterZuState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
              if (tasterZuState == LOW && endlageZuState != LOW) { // Hier würde ich auf jeden Fall die Endlage mit einbeziehen, da ansonsten der Motor zumindest startet.
                Serial.println("Taster ZU");
                TuerSteuerung(SCHLIESSEN);
              } else {                                          // Und auch beim loslassen stoppen.   
                Serial.println("Taster ZU losgelassen");
                TuerSteuerung(STOP);
              }
              lastTasterZuState    = tasterZuState;
            }
          
          

          Damit wird allerdings wieder auch im normalen Ablauf jeder Statuswechsel bearbeitet, aber zumindest die höher priorisierten zuerst.
          Da gibt es aber auch noch Möglichkeiten. Falls nötig muss ich da noch einmal drüber scchauen.

          Schöne Grüße
          Andreas

          ioBroker auf Raspberry 4 mit SSD. Homematik IP mit CCU 3. Shelly. MySQL. Arduino. ...

          Meine Posts sind subjektiv und manipulativ, erheben Anspruch auf Allwissenheit und können Spuren von Ironie oder Sarkasmus enthalten. ;-)

          T 1 Antwort Letzte Antwort
          0
          • AndreiosA Andreios

            @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

            @Andreas-5

            Wie kann man verhindern, das nach einem Neustart des WEMOS der alte Fahrbefehl vom mqtt ignoriert wird. Das gleiche Problem wird auch auftreten, wenn er die Verbindung zum mqtt-Broker verliert. hast du da eine Idee.

            Zum Einen müsste der MQTT-Server dem Subscriber die letzten Befehle/Status senden. Das ist eine Einstellungssache, aber vielleicht ist das ja schon so eingestellt.

            Dann müsste der Statusmerker undefiniert sein, also z.B. -1, aktuell sind die auf 1:

            int lastTasterAufState = 1;
            int tasterAufState = 1;
            int lastTasterZuState = 1;
            int tasterZuState = 1;
            int lastTasterStoppState = 1;
            int tasterStoppState = 1;
            
            

            Wahrscheinlich, um den "normalen" Status 0 nach dem Start mit zu bekommen.
            Wenn die auf einem nicht gültigen Wert stehen, wird auf jeden Fall einmal der Status erwischt.
            Aber ACHTUNG: So wie ich das mit den Abfragen umgestellt habe, um die Prio hinein zu bringen funktioniert das nicht, weil am Ende alle Merker gesetzt werden und durch die else if nur immer einer pro Zyklus bearbeitet wird.
            In dem Fall würde ich das Setzen der Merker jeweils an das Ende jedes if-Block setzen:

              if (tasterStoppState != lastTasterStoppState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
                // Stoptaster und Richtung Zu löst Halt aus
                if ((tasterStoppState == LOW) && (richtung == 2)) {
                  Serial.println("Taster Stop LOW");
                  TuerSteuerung(STOP);
                } else {
                  Serial.println("Taster Stop High"); // Lichtschranke wieder frei
                  if (richtung == 2) // Nur dann, wenn vorher auch schon SCHLIESSEN aktiv war, hier weiter fahren, wenn Lichtschranke frei.
                    TuerSteuerung(SCHLIESSEN);
                }
                lastTasterStoppState = tasterStoppState;
              }
              else if (endlageAufState != lastEndlageAufState) { // Abfrage damit nicht bei jedem Durchlauf die Endlage neu gesetzt wird, sondern nur bei Änderung
                if (endlageAufState == LOW) {
                  TuerEndlagen(TUERAUF);
                }
              }
              else if (endlageZuState != lastEndlageZuState) { // Abfrage damit nicht bei jedem Durchlauf die Endlage neu gesetzt wird, sondern nur bei Änderung
                if (endlageZuState == LOW) {
                  TuerEndlagen(TUERZU);
                }
                lastEndlageAufState  = endlageAufState;
                lastEndlageZuState   = endlageZuState;
              }
              else if (tasterAufState != lastTasterAufState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
                if (tasterAufState == LOW && endlageAufState != LOW) { // Hier würde ich auf jeden Fall die Endlage mit einbeziehen, da ansonsten der Motor zumindest startet.
                  Serial.println("Taster AUF");
                  TuerSteuerung(OEFFNEN);
                } else {                                          // Und auch beim loslassen stoppen.
                  Serial.println("Taster AUF losgelassen");
                  TuerSteuerung(STOP);
                }
                lastTasterAufState   = tasterAufState;
              }
              else if (tasterZuState != lastTasterZuState) { // Abfrage damit nur bei Änderung am Taster Aktion ausgeführt wird
                if (tasterZuState == LOW && endlageZuState != LOW) { // Hier würde ich auf jeden Fall die Endlage mit einbeziehen, da ansonsten der Motor zumindest startet.
                  Serial.println("Taster ZU");
                  TuerSteuerung(SCHLIESSEN);
                } else {                                          // Und auch beim loslassen stoppen.   
                  Serial.println("Taster ZU losgelassen");
                  TuerSteuerung(STOP);
                }
                lastTasterZuState    = tasterZuState;
              }
            
            

            Damit wird allerdings wieder auch im normalen Ablauf jeder Statuswechsel bearbeitet, aber zumindest die höher priorisierten zuerst.
            Da gibt es aber auch noch Möglichkeiten. Falls nötig muss ich da noch einmal drüber scchauen.

            T Offline
            T Offline
            TT-Tom
            schrieb am zuletzt editiert von
            #134

            @andreas-5
            Wir warten mal auf @Beowolf seine Antworten.
            Habe das Stop ja noch einmal angepasst und wenn er bis jetzt noch kein Problem mit dem MQTT hatte, lassen wir es erstmal so. Vielleicht fällt mir dazu noch was ein.

            Gruß Tom
            https://github.com/tt-tom17
            Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

            NSPanel Script Wiki
            https://github.com/joBr99/nspanel-lovelace-ui/wiki

            NSPanel Adapter Wiki
            https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

            1 Antwort Letzte Antwort
            0
            • T TT-Tom

              @andreas-5
              okay, ich ja auch nicht habe immer externe Widerstände genutzt.

              Hast du noch eine Idee zum MQTT-Problem?

              @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

              B Offline
              B Offline
              Beowolf
              schrieb am zuletzt editiert von
              #135

              @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

              @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

              Jepp. Schon gemerkt. Die Tür fährt zu.

              Besser wäre es glaube ich, wenn die Tür nichts machen würde.

              Zu der aktuellen Version.

              Tastersteuerung geht fast.

              1. Taste für AUFgedrückt - Tür fährt auf solange ich den Taster gedrückt halte - bis zum Endschalter - Tür hält an.

              ABER

              Wenn ich nun den Taster für ZU drücke möchte die Tür noch weiter auf fahren.

              Auch bleibt die LED auf weiß wenn ich per Taster die Tür zu gefahren habe.

              Das sind aber alles Dinge die im Normnalbetrieb glaube ich vollkommen egal sind.

              Die Natur braucht nicht unseren Schutz, sie braucht unsere Abwesenheit.

              T AndreiosA 2 Antworten Letzte Antwort
              0
              • B Beowolf

                @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

                Jepp. Schon gemerkt. Die Tür fährt zu.

                Besser wäre es glaube ich, wenn die Tür nichts machen würde.

                Zu der aktuellen Version.

                Tastersteuerung geht fast.

                1. Taste für AUFgedrückt - Tür fährt auf solange ich den Taster gedrückt halte - bis zum Endschalter - Tür hält an.

                ABER

                Wenn ich nun den Taster für ZU drücke möchte die Tür noch weiter auf fahren.

                Auch bleibt die LED auf weiß wenn ich per Taster die Tür zu gefahren habe.

                Das sind aber alles Dinge die im Normnalbetrieb glaube ich vollkommen egal sind.

                T Offline
                T Offline
                TT-Tom
                schrieb am zuletzt editiert von
                #136

                @beowolf

                ich konnte leider es nicht nachstellen. Kannst du bitte mal im IoBroker den Meldungen im MQTT mit kontrollieren, wenn du von Hand fährst?

                Hast du die Möglichkeit dich per USB Kabel mit dem WEMOS zu verbinden und mit Arduino IDE die Debugmeldungen im seriellen Monitor mit zu lesen?

                Das mit de LED sehe ich mir nochmal an.

                Gruß Tom
                https://github.com/tt-tom17
                Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                NSPanel Script Wiki
                https://github.com/joBr99/nspanel-lovelace-ui/wiki

                NSPanel Adapter Wiki
                https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

                B 1 Antwort Letzte Antwort
                0
                • T TT-Tom

                  @beowolf

                  ich konnte leider es nicht nachstellen. Kannst du bitte mal im IoBroker den Meldungen im MQTT mit kontrollieren, wenn du von Hand fährst?

                  Hast du die Möglichkeit dich per USB Kabel mit dem WEMOS zu verbinden und mit Arduino IDE die Debugmeldungen im seriellen Monitor mit zu lesen?

                  Das mit de LED sehe ich mir nochmal an.

                  B Offline
                  B Offline
                  Beowolf
                  schrieb am zuletzt editiert von
                  #137

                  @tt-tom
                  Tür ist ZU - drücke Taster Tür auf bis Tür an Endschalter kommt

                  Taster AUF
                  Neuer Fahrbefehl
                  Tuer oeffnet ... Motor angehalten - Endlage erreicht
                  Tuer geoeffnet
                  Taster AUF losgelassen
                  Neuer Fahrbefehl
                  Motor angehalten über Taster
                  
                  

                  Jetzt ist die Tür auf - rote LED war an - weisse geht an wenn ich den Taster loaslasse.

                  Tür ist AUF - Taste für Tür ZU gedrückt bis Tür an Endschalter kommt

                  Taster ZU
                  Neuer Fahrbefehl
                  Tuer schliesst ... Motor angehalten - Endlage erreicht
                  Tuer geschlossen
                  Taster ZU losgelassen
                  Neuer Fahrbefehl
                  Motor angehalten über Taster
                  
                  

                  Jetzt ist die Tür zu - grüne LED war an - weisse geht an wenn ich den Taster loaslasse.

                  Tür ist ZU - drücke Taster Tür auf bis Tür an Endschalter kommt

                  Taster AUF
                  Neuer Fahrbefehl
                  Tuer oeffnet ... Motor angehalten - Endlage erreicht
                  Tuer geoeffnet
                  Taster AUF losgelassen
                  Neuer Fahrbefehl
                  Motor angehalten über Taster
                  Taster ZU
                  Neuer Fahrbefehl
                  Tuer schliesst ... Motor angehalten - Endlage erreicht
                  Tuer geschlossen
                  Taster ZU losgelassen
                  Neuer Fahrbefehl
                  Motor angehalten über Taster
                  Taster ZU losgelassen
                  Neuer Fahrbefehl
                  Motor angehalten über Taster
                  
                  

                  Tür ist AUF - Taste für Tür ZU gedrückt bis Tür an Endschalter kommt

                  Wenn ich jetzt direkt auf die ZU-TASTE drücke fährt die Tür noch ein klein wenig auf und geht dann langsam zu.

                  Das wird hiermit zusammen hängen

                  const unsigned int TuerbewegungZu =  61000;
                  const unsigned int TuerbewegungAuf = -61000;
                  

                  Der Motor fährt bis zu diesen Werten ÜBER die Endschalter und fährt dann wieder in die entgegengesetzte Richtung. Das scheint im "Hintergrund" weiter zu laufen. Je nachdem wie schnell ich den ZU Taster drücke dreht der Motor mehr oder weniger noch nach.

                  Das ist alles ok so - es handelt sich immer noch um eine Hühnertür, nicht um einen Hochsicherheitssafe. :flushed:

                  Die Natur braucht nicht unseren Schutz, sie braucht unsere Abwesenheit.

                  B T 2 Antworten Letzte Antwort
                  0
                  • B Beowolf

                    @tt-tom
                    Tür ist ZU - drücke Taster Tür auf bis Tür an Endschalter kommt

                    Taster AUF
                    Neuer Fahrbefehl
                    Tuer oeffnet ... Motor angehalten - Endlage erreicht
                    Tuer geoeffnet
                    Taster AUF losgelassen
                    Neuer Fahrbefehl
                    Motor angehalten über Taster
                    
                    

                    Jetzt ist die Tür auf - rote LED war an - weisse geht an wenn ich den Taster loaslasse.

                    Tür ist AUF - Taste für Tür ZU gedrückt bis Tür an Endschalter kommt

                    Taster ZU
                    Neuer Fahrbefehl
                    Tuer schliesst ... Motor angehalten - Endlage erreicht
                    Tuer geschlossen
                    Taster ZU losgelassen
                    Neuer Fahrbefehl
                    Motor angehalten über Taster
                    
                    

                    Jetzt ist die Tür zu - grüne LED war an - weisse geht an wenn ich den Taster loaslasse.

                    Tür ist ZU - drücke Taster Tür auf bis Tür an Endschalter kommt

                    Taster AUF
                    Neuer Fahrbefehl
                    Tuer oeffnet ... Motor angehalten - Endlage erreicht
                    Tuer geoeffnet
                    Taster AUF losgelassen
                    Neuer Fahrbefehl
                    Motor angehalten über Taster
                    Taster ZU
                    Neuer Fahrbefehl
                    Tuer schliesst ... Motor angehalten - Endlage erreicht
                    Tuer geschlossen
                    Taster ZU losgelassen
                    Neuer Fahrbefehl
                    Motor angehalten über Taster
                    Taster ZU losgelassen
                    Neuer Fahrbefehl
                    Motor angehalten über Taster
                    
                    

                    Tür ist AUF - Taste für Tür ZU gedrückt bis Tür an Endschalter kommt

                    Wenn ich jetzt direkt auf die ZU-TASTE drücke fährt die Tür noch ein klein wenig auf und geht dann langsam zu.

                    Das wird hiermit zusammen hängen

                    const unsigned int TuerbewegungZu =  61000;
                    const unsigned int TuerbewegungAuf = -61000;
                    

                    Der Motor fährt bis zu diesen Werten ÜBER die Endschalter und fährt dann wieder in die entgegengesetzte Richtung. Das scheint im "Hintergrund" weiter zu laufen. Je nachdem wie schnell ich den ZU Taster drücke dreht der Motor mehr oder weniger noch nach.

                    Das ist alles ok so - es handelt sich immer noch um eine Hühnertür, nicht um einen Hochsicherheitssafe. :flushed:

                    B Offline
                    B Offline
                    Beowolf
                    schrieb am zuletzt editiert von
                    #138

                    Was mir etwas wichtiger ist, ist das der Motor still ist nach einem Reset bzw. Stromausfall oder so.

                    Die Natur braucht nicht unseren Schutz, sie braucht unsere Abwesenheit.

                    T 1 Antwort Letzte Antwort
                    0
                    • B Beowolf

                      Was mir etwas wichtiger ist, ist das der Motor still ist nach einem Reset bzw. Stromausfall oder so.

                      T Offline
                      T Offline
                      TT-Tom
                      schrieb am zuletzt editiert von
                      #139

                      @beowolf

                      wenn der Motor die Endlage erreicht hat sollte er stumm sein. Das sollte über diese Funktion ausgelöst werden.

                      void stopp() {
                        stepper.stop();
                        digitalWrite(MotorStatus, HIGH); //Motor deaktiviert
                      }
                      

                      diese wird über die Endlagen aufgerufen.
                      Damit der Motor nach dem Reset / Neustart ruhig bleibt, sollte im Setup folgende Zeile eingetragen werden.

                      digitalWrite(MotorStatus, HIGH); //Motor deaktiviert
                      

                      Damit die LED beim Taster loslassen nicht die Farbe wechselt, kannst du die beiden Zeilen aus kommentieren

                          case STOP_TASTER:
                            stopp();
                            richtung = 0;
                            Serial.println("Motor angehalten über Taster");
                       //     pixels.setPixelColor(0, pixels.Color(255, 255, 255)); //LED Farbe weiss
                       //     pixels.show();
                            break;
                      
                      

                      Gruß Tom
                      https://github.com/tt-tom17
                      Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                      NSPanel Script Wiki
                      https://github.com/joBr99/nspanel-lovelace-ui/wiki

                      NSPanel Adapter Wiki
                      https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

                      B 1 Antwort Letzte Antwort
                      0
                      • B Beowolf

                        @tt-tom
                        Tür ist ZU - drücke Taster Tür auf bis Tür an Endschalter kommt

                        Taster AUF
                        Neuer Fahrbefehl
                        Tuer oeffnet ... Motor angehalten - Endlage erreicht
                        Tuer geoeffnet
                        Taster AUF losgelassen
                        Neuer Fahrbefehl
                        Motor angehalten über Taster
                        
                        

                        Jetzt ist die Tür auf - rote LED war an - weisse geht an wenn ich den Taster loaslasse.

                        Tür ist AUF - Taste für Tür ZU gedrückt bis Tür an Endschalter kommt

                        Taster ZU
                        Neuer Fahrbefehl
                        Tuer schliesst ... Motor angehalten - Endlage erreicht
                        Tuer geschlossen
                        Taster ZU losgelassen
                        Neuer Fahrbefehl
                        Motor angehalten über Taster
                        
                        

                        Jetzt ist die Tür zu - grüne LED war an - weisse geht an wenn ich den Taster loaslasse.

                        Tür ist ZU - drücke Taster Tür auf bis Tür an Endschalter kommt

                        Taster AUF
                        Neuer Fahrbefehl
                        Tuer oeffnet ... Motor angehalten - Endlage erreicht
                        Tuer geoeffnet
                        Taster AUF losgelassen
                        Neuer Fahrbefehl
                        Motor angehalten über Taster
                        Taster ZU
                        Neuer Fahrbefehl
                        Tuer schliesst ... Motor angehalten - Endlage erreicht
                        Tuer geschlossen
                        Taster ZU losgelassen
                        Neuer Fahrbefehl
                        Motor angehalten über Taster
                        Taster ZU losgelassen
                        Neuer Fahrbefehl
                        Motor angehalten über Taster
                        
                        

                        Tür ist AUF - Taste für Tür ZU gedrückt bis Tür an Endschalter kommt

                        Wenn ich jetzt direkt auf die ZU-TASTE drücke fährt die Tür noch ein klein wenig auf und geht dann langsam zu.

                        Das wird hiermit zusammen hängen

                        const unsigned int TuerbewegungZu =  61000;
                        const unsigned int TuerbewegungAuf = -61000;
                        

                        Der Motor fährt bis zu diesen Werten ÜBER die Endschalter und fährt dann wieder in die entgegengesetzte Richtung. Das scheint im "Hintergrund" weiter zu laufen. Je nachdem wie schnell ich den ZU Taster drücke dreht der Motor mehr oder weniger noch nach.

                        Das ist alles ok so - es handelt sich immer noch um eine Hühnertür, nicht um einen Hochsicherheitssafe. :flushed:

                        T Offline
                        T Offline
                        TT-Tom
                        schrieb am zuletzt editiert von
                        #140

                        @beowolf sagte in GPIO Status Wemos d1 mini an iobroker senden:

                        Wenn ich jetzt direkt auf die ZU-TASTE drücke fährt die Tür noch ein klein wenig auf und geht dann langsam zu.

                        Das wird hiermit zusammen hängen

                        const unsigned int TuerbewegungZu =  61000;
                        const unsigned int TuerbewegungAuf = -61000;
                        

                        Der Motor fährt bis zu diesen Werten ÜBER die Endschalter und fährt dann wieder in die entgegengesetzte Richtung. Das scheint im "Hintergrund" weiter zu laufen. Je nachdem wie schnell ich den ZU Taster drücke dreht der Motor mehr oder weniger noch nach.

                        Das ist alles ok so - es handelt sich immer noch um eine Hühnertür, nicht um einen Hochsicherheitssafe. :flushed:

                        muss mir mal die <AccelStepper.h> ansehen ob es ein Kommando gibt damit er nicht weiter läuft. Denn der stop Befehl hält in anscheint nur an und bei Run läuft er weiter bis ende erreicht ist.

                        Gruß Tom
                        https://github.com/tt-tom17
                        Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                        NSPanel Script Wiki
                        https://github.com/joBr99/nspanel-lovelace-ui/wiki

                        NSPanel Adapter Wiki
                        https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

                        B 1 Antwort Letzte Antwort
                        0
                        • T TT-Tom

                          @beowolf sagte in GPIO Status Wemos d1 mini an iobroker senden:

                          Wenn ich jetzt direkt auf die ZU-TASTE drücke fährt die Tür noch ein klein wenig auf und geht dann langsam zu.

                          Das wird hiermit zusammen hängen

                          const unsigned int TuerbewegungZu =  61000;
                          const unsigned int TuerbewegungAuf = -61000;
                          

                          Der Motor fährt bis zu diesen Werten ÜBER die Endschalter und fährt dann wieder in die entgegengesetzte Richtung. Das scheint im "Hintergrund" weiter zu laufen. Je nachdem wie schnell ich den ZU Taster drücke dreht der Motor mehr oder weniger noch nach.

                          Das ist alles ok so - es handelt sich immer noch um eine Hühnertür, nicht um einen Hochsicherheitssafe. :flushed:

                          muss mir mal die <AccelStepper.h> ansehen ob es ein Kommando gibt damit er nicht weiter läuft. Denn der stop Befehl hält in anscheint nur an und bei Run läuft er weiter bis ende erreicht ist.

                          B Offline
                          B Offline
                          Beowolf
                          schrieb am zuletzt editiert von
                          #141

                          @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                          muss mir mal die <AccelStepper.h> ansehen ob es ein Kommando gibt damit er nicht weiter läuft. Denn der stop Befehl hält in anscheint nur an und bei Run läuft er weiter bis ende erreicht ist.

                          So fühlt sich das an

                          Die Natur braucht nicht unseren Schutz, sie braucht unsere Abwesenheit.

                          1 Antwort Letzte Antwort
                          0
                          • T TT-Tom

                            @beowolf

                            wenn der Motor die Endlage erreicht hat sollte er stumm sein. Das sollte über diese Funktion ausgelöst werden.

                            void stopp() {
                              stepper.stop();
                              digitalWrite(MotorStatus, HIGH); //Motor deaktiviert
                            }
                            

                            diese wird über die Endlagen aufgerufen.
                            Damit der Motor nach dem Reset / Neustart ruhig bleibt, sollte im Setup folgende Zeile eingetragen werden.

                            digitalWrite(MotorStatus, HIGH); //Motor deaktiviert
                            

                            Damit die LED beim Taster loslassen nicht die Farbe wechselt, kannst du die beiden Zeilen aus kommentieren

                                case STOP_TASTER:
                                  stopp();
                                  richtung = 0;
                                  Serial.println("Motor angehalten über Taster");
                             //     pixels.setPixelColor(0, pixels.Color(255, 255, 255)); //LED Farbe weiss
                             //     pixels.show();
                                  break;
                            
                            
                            B Offline
                            B Offline
                            Beowolf
                            schrieb am zuletzt editiert von
                            #142

                            @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                            Damit der Motor nach dem Reset / Neustart ruhig bleibt, sollte im Setup folgende Zeile eingetragen werden.
                            digitalWrite(MotorStatus, HIGH); //Motor deaktiviert

                            Dann ist der Motor solange unter "Dampf" bis der erste Fahrbefehl kommt - nicht gut.

                            Die Natur braucht nicht unseren Schutz, sie braucht unsere Abwesenheit.

                            T 1 Antwort Letzte Antwort
                            0
                            • B Beowolf

                              @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                              Damit der Motor nach dem Reset / Neustart ruhig bleibt, sollte im Setup folgende Zeile eingetragen werden.
                              digitalWrite(MotorStatus, HIGH); //Motor deaktiviert

                              Dann ist der Motor solange unter "Dampf" bis der erste Fahrbefehl kommt - nicht gut.

                              T Offline
                              T Offline
                              TT-Tom
                              schrieb am zuletzt editiert von
                              #143

                              @beowolf

                              Mit dem Befehl wird der Motor doch deaktiviert, oder habe ich das falsch verstanden?

                              Gruß Tom
                              https://github.com/tt-tom17
                              Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                              NSPanel Script Wiki
                              https://github.com/joBr99/nspanel-lovelace-ui/wiki

                              NSPanel Adapter Wiki
                              https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

                              B 1 Antwort Letzte Antwort
                              0
                              • T TT-Tom

                                @beowolf

                                Mit dem Befehl wird der Motor doch deaktiviert, oder habe ich das falsch verstanden?

                                B Offline
                                B Offline
                                Beowolf
                                schrieb am zuletzt editiert von Beowolf
                                #144

                                @tt-tom

                                Stimmt, aber der Motor zeigt das aber so.

                                Der "Ursprungserzeuger" des Programms, nutzt inzwischen die Schrittmotoransteuerung durch die MobaTools. Er sagt, das die per Interrupt getaktet werden, was meist besser funktioniert.

                                Ich kenne die Tools aber nicht.

                                Die Natur braucht nicht unseren Schutz, sie braucht unsere Abwesenheit.

                                1 Antwort Letzte Antwort
                                0
                                • B Beowolf

                                  @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                  @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

                                  Jepp. Schon gemerkt. Die Tür fährt zu.

                                  Besser wäre es glaube ich, wenn die Tür nichts machen würde.

                                  Zu der aktuellen Version.

                                  Tastersteuerung geht fast.

                                  1. Taste für AUFgedrückt - Tür fährt auf solange ich den Taster gedrückt halte - bis zum Endschalter - Tür hält an.

                                  ABER

                                  Wenn ich nun den Taster für ZU drücke möchte die Tür noch weiter auf fahren.

                                  Auch bleibt die LED auf weiß wenn ich per Taster die Tür zu gefahren habe.

                                  Das sind aber alles Dinge die im Normnalbetrieb glaube ich vollkommen egal sind.

                                  AndreiosA Offline
                                  AndreiosA Offline
                                  Andreios
                                  Forum Testing
                                  schrieb am zuletzt editiert von
                                  #145

                                  @beowolf sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                  @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                  @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

                                  Jepp. Schon gemerkt. Die Tür fährt zu.

                                  Besser wäre es glaube ich, wenn die Tür nichts machen würde.

                                  Zu der aktuellen Version.

                                  Tastersteuerung geht fast.

                                  1. Taste für AUFgedrückt - Tür fährt auf solange ich den Taster gedrückt halte - bis zum Endschalter - Tür hält an.

                                  ABER

                                  Wenn ich nun den Taster für ZU drücke möchte die Tür noch weiter auf fahren.

                                  Auch bleibt die LED auf weiß wenn ich per Taster die Tür zu gefahren habe.

                                  Das sind aber alles Dinge die im Normnalbetrieb glaube ich vollkommen egal sind.

                                  @beowolf sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                  @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                  @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

                                  Jepp. Schon gemerkt. Die Tür fährt zu.

                                  Besser wäre es glaube ich, wenn die Tür nichts machen würde.

                                  Was dabei zu prüfen wäre ist, ob der Motor beim Neueinschalten sein altes Ziel noch hat, dann müsste das im Setup zurückgesetzt werden, falls möglich.
                                  Außerdem für den Startlauf die Merker z.B. -1 definieren und damit erst einmal nicht auf gesetzte Tasten reagieren (Flankenerkennung), so dass also selbst dann, wenn Du wirklich beim Einschalten des Wemos die Taste gedrückt hälst, das ignoriert wird.
                                  Aktuell ist es so, dass, da der Merker auf 0 steht, wenn die Taste beim Start gedrückt ist, eine positive Flanke erkannt wird, der Motor läuft ggfs. los.
                                  Ist der Merker beim Start auf -1 und die Flanke wird damit ignoriert, dann steht der Merker danach auf 1 und ab da läuft alles ganz normal, zuerst kommt die negative Flanke, wenn die Taste losgelassen wird und der Merker wird 0.

                                  Schöne Grüße
                                  Andreas

                                  ioBroker auf Raspberry 4 mit SSD. Homematik IP mit CCU 3. Shelly. MySQL. Arduino. ...

                                  Meine Posts sind subjektiv und manipulativ, erheben Anspruch auf Allwissenheit und können Spuren von Ironie oder Sarkasmus enthalten. ;-)

                                  T 1 Antwort Letzte Antwort
                                  0
                                  • AndreiosA Andreios

                                    @beowolf sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                    @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                    @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

                                    Jepp. Schon gemerkt. Die Tür fährt zu.

                                    Besser wäre es glaube ich, wenn die Tür nichts machen würde.

                                    Zu der aktuellen Version.

                                    Tastersteuerung geht fast.

                                    1. Taste für AUFgedrückt - Tür fährt auf solange ich den Taster gedrückt halte - bis zum Endschalter - Tür hält an.

                                    ABER

                                    Wenn ich nun den Taster für ZU drücke möchte die Tür noch weiter auf fahren.

                                    Auch bleibt die LED auf weiß wenn ich per Taster die Tür zu gefahren habe.

                                    Das sind aber alles Dinge die im Normnalbetrieb glaube ich vollkommen egal sind.

                                    @beowolf sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                    @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                    @Beowolf ist dir das schon mal aufgefallen das die Tür nach einem Neustart des WEMOS losgefahren ist?

                                    Jepp. Schon gemerkt. Die Tür fährt zu.

                                    Besser wäre es glaube ich, wenn die Tür nichts machen würde.

                                    Was dabei zu prüfen wäre ist, ob der Motor beim Neueinschalten sein altes Ziel noch hat, dann müsste das im Setup zurückgesetzt werden, falls möglich.
                                    Außerdem für den Startlauf die Merker z.B. -1 definieren und damit erst einmal nicht auf gesetzte Tasten reagieren (Flankenerkennung), so dass also selbst dann, wenn Du wirklich beim Einschalten des Wemos die Taste gedrückt hälst, das ignoriert wird.
                                    Aktuell ist es so, dass, da der Merker auf 0 steht, wenn die Taste beim Start gedrückt ist, eine positive Flanke erkannt wird, der Motor läuft ggfs. los.
                                    Ist der Merker beim Start auf -1 und die Flanke wird damit ignoriert, dann steht der Merker danach auf 1 und ab da läuft alles ganz normal, zuerst kommt die negative Flanke, wenn die Taste losgelassen wird und der Merker wird 0.

                                    T Offline
                                    T Offline
                                    TT-Tom
                                    schrieb am zuletzt editiert von
                                    #146

                                    @andreas-5 @Beowolf
                                    Ich glaube, ich habe das jetzt mit der Stepper verstanden. Der Tip war MobaTools. Ich bin auch im Moba Verein und dort nutzen wir Servos zum Steuern der Weichen. Im Prinzip das selbe wie mit einem Stepper. Wir messen / testen bis wir die richtige Lage der Weiche erreicht haben, und speichern den Wert. Da gibt es keine Endlagenschalter und wenn sind sie nur zur Anzeige. Die Steuerung funktioniert alleine über die Wegstrecke / Schritte.

                                    Soll heissen @Beowolf, du musst deine Schritte von Auf nach Zu noch einmal ausmessen, damit sie im Bereich der Endlagen anhält. Eine Abschaltung und "Reset" des Stepper bringt nix, im schlimmsten Fall verschiebt sich dadurch sein Fahrbereich, weil er immer die gesamten Schritte fahren will.

                                    Ich hoffe ich habe mich gut ausgedrückt und ihr habt es verstanden.

                                    Mit MQTT müsste auch über ein State bzw. Zeitstempel überwacht werden. Aber in der Materie bin ich noch nicht so fit.

                                    Gruß Tom

                                    Gruß Tom
                                    https://github.com/tt-tom17
                                    Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                                    NSPanel Script Wiki
                                    https://github.com/joBr99/nspanel-lovelace-ui/wiki

                                    NSPanel Adapter Wiki
                                    https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

                                    B 1 Antwort Letzte Antwort
                                    0
                                    • T TT-Tom

                                      @andreas-5 @Beowolf
                                      Ich glaube, ich habe das jetzt mit der Stepper verstanden. Der Tip war MobaTools. Ich bin auch im Moba Verein und dort nutzen wir Servos zum Steuern der Weichen. Im Prinzip das selbe wie mit einem Stepper. Wir messen / testen bis wir die richtige Lage der Weiche erreicht haben, und speichern den Wert. Da gibt es keine Endlagenschalter und wenn sind sie nur zur Anzeige. Die Steuerung funktioniert alleine über die Wegstrecke / Schritte.

                                      Soll heissen @Beowolf, du musst deine Schritte von Auf nach Zu noch einmal ausmessen, damit sie im Bereich der Endlagen anhält. Eine Abschaltung und "Reset" des Stepper bringt nix, im schlimmsten Fall verschiebt sich dadurch sein Fahrbereich, weil er immer die gesamten Schritte fahren will.

                                      Ich hoffe ich habe mich gut ausgedrückt und ihr habt es verstanden.

                                      Mit MQTT müsste auch über ein State bzw. Zeitstempel überwacht werden. Aber in der Materie bin ich noch nicht so fit.

                                      Gruß Tom

                                      B Offline
                                      B Offline
                                      Beowolf
                                      schrieb am zuletzt editiert von Beowolf
                                      #147

                                      @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                      du musst deine Schritte von Auf nach Zu noch einmal ausmessen,

                                      Das war auch so geplant. Bis jetzt war es nur so, das ich sicher sein wollte, das die Endlage der Tür durch die Endschalter definiert wird. Es gehen schon mal Schritte verloren. Deshalb das "zu viel" an Schritten.

                                      Ich h offe auch, das dieses ganze gefummel mit den Taster ganz selten gebraucht wird. Per ioBroker morgens Tür auf - abends wieder zu - fertig. Nur die Zeiten verschieben sich.

                                      Die Natur braucht nicht unseren Schutz, sie braucht unsere Abwesenheit.

                                      T 1 Antwort Letzte Antwort
                                      0
                                      • B Beowolf

                                        @tt-tom sagte in GPIO Status Wemos d1 mini an iobroker senden:

                                        du musst deine Schritte von Auf nach Zu noch einmal ausmessen,

                                        Das war auch so geplant. Bis jetzt war es nur so, das ich sicher sein wollte, das die Endlage der Tür durch die Endschalter definiert wird. Es gehen schon mal Schritte verloren. Deshalb das "zu viel" an Schritten.

                                        Ich h offe auch, das dieses ganze gefummel mit den Taster ganz selten gebraucht wird. Per ioBroker morgens Tür auf - abends wieder zu - fertig. Nur die Zeiten verschieben sich.

                                        T Offline
                                        T Offline
                                        TT-Tom
                                        schrieb am zuletzt editiert von
                                        #148

                                        @beowolf

                                        habe nochmal mit den Einstellungen vom MQTT Adapter gespielt. Bei folgenden Einstellungen ist die Tür bei mir nicht mehr gefahren, weder beim Neustart des Adapter noch beim Neustart des WEMOS.

                                        "Eigene States beim Verbinden publizieren" und "States bei subscribe publizieren" habe ich beide deaktiviert.

                                        ich weiß jetzt nicht ob du noch andere Projekte hast die diese Einstellung benötigen.

                                        Gruß Tom
                                        https://github.com/tt-tom17
                                        Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                                        NSPanel Script Wiki
                                        https://github.com/joBr99/nspanel-lovelace-ui/wiki

                                        NSPanel Adapter Wiki
                                        https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

                                        B 1 Antwort Letzte Antwort
                                        0
                                        • T TT-Tom

                                          @beowolf

                                          habe nochmal mit den Einstellungen vom MQTT Adapter gespielt. Bei folgenden Einstellungen ist die Tür bei mir nicht mehr gefahren, weder beim Neustart des Adapter noch beim Neustart des WEMOS.

                                          "Eigene States beim Verbinden publizieren" und "States bei subscribe publizieren" habe ich beide deaktiviert.

                                          ich weiß jetzt nicht ob du noch andere Projekte hast die diese Einstellung benötigen.

                                          B Offline
                                          B Offline
                                          Beowolf
                                          schrieb am zuletzt editiert von
                                          #149

                                          @tt-tom
                                          Jepp - geht.

                                          Muß ich mal beobachten ob andere Dinge jetzt Probleme haben.

                                          Die Natur braucht nicht unseren Schutz, sie braucht unsere Abwesenheit.

                                          B 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

                                          971

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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