IR Send über MQTT gesteuert, keine Reaktion der Geräte

Moin zusammen
ich verzweifle langsam.
Aber der Reihe nach.
Meine Idee ist, das ich über einen Schalter in Openhab mein "Kino" ein- oder ausschalten kann.
Dabei soll die Leinwand runter oder eben raufgefahren werden. Der Beamer soll sich ein- oder ausschalten und der Receiver ebenso.
Angebunden ist das ganze per MQTT
Nach dem Flashen verbindes sich der ESP auch mit dem WLAN, baut eine Verbindung zu Mosquito auf.
Ich kann dann auch per Schalter (also 0 oder 1) das Szenario starten.
Die einzelnen Schritte werden sauber abgearbeitet, es wird zumindest alles brav in die Konsole geschrieben.

Aber egal was ich benutze, es werden keine Signale gesendet.

Ich habe 940nm LED (BESTOMZ) und iHaospace Digital 38khz Ir Receiver Ir Transmitter Sensor versucht.
die 940nm LED habe ich mit einem 100Ohm Widerstand verbunden.

Also Board habe ich einmal AZDelivery NodeMCU Amica Modul V2 ESP8266 ESP-12F und ein Wemos D1 Mini versucht.

Beim NodeMCU habe ich ich Minus und D5 (GPIO14) Lt. Beschreibung (IR_T)
Beim Wemos D5 und Masse
Die Signale habe ich mit dem Beispielsketch ausgelesen, daran sollte es hoffentlich nicht liegen.
Zwei Beispielsketche dienten mir auch als Grundlage für meinen Code
Hier einmal mein Sketch

Evtl. mache auch einen Fehler beim senden.

/*
 Basic ESP8266 MQTT example
 This sketch demonstrates the capabilities of the pubsub library in combination
 with the ESP8266 board/library.
 It connects to an MQTT server then:
  - publishes "hello world" to the topic "outTopic" every two seconds
  - subscribes to the topic "inTopic", printing out any messages
    it receives. NB - it assumes the received payloads are strings not binary
  - If the first character of the topic "inTopic" is an 1, switch ON the ESP Led,
    else switch it off
 It will reconnect to the server if the connection is lost using a blocking
 reconnect function. See the 'mqtt_reconnect_nonblocking' example for how to
 achieve the same result without blocking the main loop.
 To install the ESP8266 board, (using Arduino 1.6.4+):
  - Add the following 3rd party board manager under "File -> Preferences -> Additional Boards Manager URLs":
       http://arduino.esp8266.com/stable/package_esp8266com_index.json
  - Open the "Tools -> Board -> Board Manager" and click install for the ESP8266"
  - Select your ESP8266 in "Tools -> Board"
*/

//#include <ESP32.h>
//#include <ESP8266.h>
#include <PubSubClient.h>
#include <IRremote.hpp>
#include <IRsend.h>


const uint16_t kIrLed = 5;  // ESP8266 GPIO pin to use. Recommended: 5 (GPIO014).

IRsend IrSend(kIrLed);  // Set the GPIO to be used to sending the message.

/*
const int SenderPin = 4; // Pin tx beim NodeMCU ESP8266
IRsend irsend;
*/

//IRRemote Commands
//Generic
uint8_t Repeats = 0;




// Update these with values suitable for your network.

const char* ssid = "<SSID>";
const char* password = "<WLANKEY>";
const char* mqtt_server = "<MQTTServer>";
#define MQTT_USER  "<MQTTUSER>"
#define MQTT_PASSWORD "<MQTTPWD>"

WiFiClient espClient;
PubSubClient client(espClient);
unsigned long lastMsg = 0;
#define MSG_BUFFER_SIZE	(50)
char msg[MSG_BUFFER_SIZE];
int value = 0;

void setup_wifi() {

  delay(10);
  // We start by connecting to a WiFi network
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);

  WiFi.mode(WIFI_STA);
  WiFi.begin(ssid, password);

  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }

  randomSeed(micros());

  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
}

void callback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message arrived [");
  Serial.print(topic);
  Serial.print("] ");
  for (int i = 0; i < length; i++) {
    Serial.print((char)payload[i]);
  }
  Serial.println();

  
  if ((char)payload[0] == '1') {4
      
    //Fahre Leinwand runter
      Serial.println("Fahre Leinwand herunter");
      IrSend.sendPulseDistanceWidth(38, 450, 1350, 1300, 450, 450, 1350, 0x105555, 24, PROTOCOL_IS_LSB_FIRST, RepeatPeriodMillis, numberOfRepeats);
      delay(1000); // mindestens 5 ms Pause nach dem Senden
      //IrSender.resume();
    
    Serial.println("Schalte Beamer ein");
      IrSend.sendNEC(0xF483, 0x4F, numberOfRepeats);
      delay(1000); // mindestens 5 ms Pause nach dem Senden
         //IrSender.resume();
    Serial.println("Schalte Receiver ein");
      IrSend.sendNEC(0xA5, 0x1C, numberOfRepeats);
      delay(1000); // mindestens 5 ms Pause nach dem Senden
  
      
  } else if ((char)payload[0] == '0') {
     
      IrSend.sendNEC(0xA5, 0x1C, numberOfRepeats); //Power Code
      Serial.println("Receiver aus, wenn er an war. Sonst ist er jetzt an!");
      
      delay(10000);
    //Fahre einwand hoch
      Serial.println("Fahre Leinwand hoch");
      IrSend.sendPulseDistanceWidth(38, 450, 1350, 1350, 450, 450, 1350, 0x205555, 24, PROTOCOL_IS_LSB_FIRST, RepeatPeriodMillis, numberOfRepeats);
      delay(1000); // mindestens 5 ms Pause nach dem Senden
      //IrSend.resume();
    Serial.println("Schalte Beamer aus");
      IrSend.sendNEC(0xF483, 0x4E, numberOfRepeats);
      delay(500);
      
        //Beamer braucht eine Bestätigung
      IrSend.sendNEC(0xF483, 0x4E, numberOfRepeats);
      delay(2000); // mindestens 5 ms Pause nach dem Senden
    delay(500);
    
      
  }

}

void reconnect() {
  // Loop until we're reconnected
  while (!client.connected()) {
    Serial.print("Attempting MQTT connection...");
    // Create a random client ID
    String clientId = "Kinoszene";
    clientId += String(random(0xffff), HEX);
    // Attempt to connect
    if (client.connect(clientId.c_str(), MQTT_USER, MQTT_PASSWORD)) {
      Serial.println("connected");
      // Once connected, publish an announcement...
      //client.publish("outTopic", "hello world");
      // ... and resubscribe
      client.subscribe("Kinoszene/schalten");
     
          Serial.println("on");
          Serial.println("Kinoszene bereit");

    
     
    } else {
      Serial.print("failed, rc=");
      Serial.print(client.state());
      Serial.println(" try again in 5 seconds");
      // Wait 5 seconds before retrying
      delay(5000);
    }
  }
}

void setup() {
  Serial.begin(115200);
//  pinMode(SenderPin, OUTPUT);
  IrSend.begin();
  setup_wifi();
  client.setServer(mqtt_server, 1883);
  //client.setCredentials( "openhabian", "openhabian"); 
  client.setCallback(callback);
 
}

void loop() {

  if (!client.connected()) {
    reconnect();
  }
  client.loop();

  unsigned long now = millis();
  if (now - lastMsg > 2000) {
    lastMsg = now;
    ++value;
    //snprintf (msg, MSG_BUFFER_SIZE, "hello world #%ld", value);
    //Serial.print("Publish message: ");
    //Serial.println(msg);
    //client.publish("outTopic", msg);
  }
}

Nachtrag; als IDE nutze ich Arduino 2.2.1 auf einer Win11 Maschine

Falscher Code

Dieses wäre der mit dem ich getestet habe


#include <Arduino.h>
//#include <IRremoteESP8266.h>
#include <IRremote.hpp>
//#include <IRsend.h>

const uint16_t kIrLed = 5;  // ESP8266 GPIO pin to use. Recommended: 4 (D2).
//const uint16_t kIrLed = 3;  // Arduino Uno.


IRsend Senden(kIrLed);  // Set the GPIO to be used to sending the message.
int numberOfRepeats = 1;

void setup() {
  Serial.begin(9600);
}

void loop() {
  delay(10000);
  //Power//
  /*
  Senden.sendRC5(0x1, 0xC, numberOfRepeats);//Power Code
  Serial.println("Power");
  delay(10000);
  */
  //Volume Up//
  for (int i = 0; i < 10; i++) {
    Senden.sendPulseDistanceWidth(38, 4550, 4450, 600, 1650, 600, 550, 0xF8070707, 32, PROTOCOL_IS_LSB_FIRST, 45650, numberOfRepeats); //Volume Up Code
    Serial.println("Volume Up");
    delay(250);
  }
  
  delay(5000);
  //Volume Down//
  for (int i = 0; i < 10; i++) {
    Senden.sendPulseDistanceWidth(38, 4450, 4550, 500, 1700, 500, 650, 0xF40B0707, 32, PROTOCOL_IS_LSB_FIRST, 45650, numberOfRepeats); //Volume Down Code
    Serial.println("Volume Down");
    delay(250);
  }
  /*
  delay(5000);
  //Netflix//
  Senden.sendRC5(0x1, 0x27, numberOfRepeats); //Netflix Code
  Serial.println("Netflix");
  delay(5000);
  //Home
  Senden.sendRC5(0x1, 0x30, numberOfRepeats); //Netflix Code
  Serial.println("Home");
  delay(5000);
  //Power off//
  Senden.sendRC5(0x1, 0xC, numberOfRepeats);//Power Code
  Serial.println("Power off");
  */
  delay(10000);

}


Die IR Diode wurde nicht direkt über ESP schalten, nur über ein MOSFET.
Hast wahrscheinlich ein Smartphone mit Kamera damit kann man testen ob gesendet wird, Kamera einschalten und auf die Diode "gucken", es sollte sichtbar sein ob was gesendet wird, Kamera testen mit normaler Fernbedienung, mansche haben Infrarotfilter, selten aber doch.
Der ESP hat am Ausgang Pin 3.3V bei 100R Widerstand je nach Diode wird er überlastet, ESP8266 darf man am Pin nur mit 12mA belasten
Gibt es ein Datenblatt für deine IR Diode?

Aber die Dinger sind nicht so teuer. Wenn Du eine Empfehlung hast welche Dioden oder fertigen Module man nehmen soll, besorge ich diese

Das steht in der Beschreibung zur Diode
940nm IR Emission: 50pcs

  • Bulb Größe Durchmesser: 5mm
  • Stiftlänge: Ca. 25 mm
  • Operate Entfernung: 18 ~ 20m
  • Durchlassspannung (V): 1,2-1,5 V
  • Peak-Wellenlänge (nm): 940 nm
  • Linsenfarbe: Wasser klar
  • Vorwärtsstrom: 100mA
  • Leistung: 100mW

und der IR Transmitter
Dieses IR-Sender-Sensormodul wird direkt von einer einzelnen Röhre gestartet, es erfordert eine Wellenformmodulation durch das programm.

Mit Signalanzeige-LED, einfach zu beobachten und zu debuggen.

Es ist geeignet für Infrarot-Kommunikation, Infrarot-Fernbedienung.

Kann für die Fernsteuerung verwendet werden, kann mit Wrobot Digital 38KHz IR Transmitter Sensor kompatibel sein

Spezifikation

Spannung: 5V
Schnittstelle: Digital
Modulation: direkte Emission
Emissionsabstand: 1-2m
Modulationsfrequenz: 38 kHz
Pin-Definitionen: (1) Ausgang (2) Vcc (3) GND

Nachtrag
ich habe jetzt versucht bei beiden (Diode und iHaospace Digital 38khz Ir Transmitter) etwas mit der Kamera zu erkennen. Da sehe ich nichts, an den Fernbedienungen schon. D.h. da kommt nicht.

Suche hier im Forum nach IR Sender, das Thema war sehr oft durchgekaut.
Und noch mall nie die IR Diode direkt durch den ESP steuern, nutz ein Low level MOSFET als Treiber.
Den Empfänger teste mit den Beispielen aus der IR Bibliothek.
Erst mall testen ob alles OK danach dein Sketch.

Hi
danke für Dein feedback. Der Empfänger funktionierte direkt. Nur der Transmitter eben nicht.
Ich muss dann aufgrund Deiner Hinweise schauen wie ich sinnvoll die Spannung auf max. 1,5v bekomme.
Da muss ich mich auf die Suche machen.
Ich habe erst einmal einen Seeed Grove IT Transmitter bestellt. Mal schauen, die sollten ohne Löten funktionieren.

Der hat schon Transistor eingebaut, must mall schauen ob 3,3 V reichen wenn nicht dann 5 V nehmen.
Wenn das ankommt Foto machen das sehen wir was drauf ist, Widerstände, Transistor.

So, es hat etwas länger gedauert. Ich hatte zwischenzeitlich leider wenig Zeit.
Der Seeed Grove IT Transmitter ist angeschlossen und die Geräte, welche über NEC angesprochen werden reagieren jetzt auch.
Einzig die Leinwand macht mir noch einen Strich durch die Rechnung
Ich habe das ganze an einen D1 Mini angeschlossen. Der kann ja die 5V zur Verfügung stellen.
Die Anzahl Repeats musste ich auf 2 für NEC setzen. dann ging es auch mit Beamer und Receiver
Nur das Thema Leinwand passt nicht
Es kann nur an repeatperiodMillis oder Numberofrepeats liegen. Den Rest hat die Library beim Empfang des Signals schon vorgegeben
Das wäre der Befehl

IrSend.sendPulseDistanceWidth(38, 450, 1350, 1350, 450, 450, 1350, 0x205555, 24, PROTOCOL_IS_LSB_FIRST, RepeatPeriodMillis, numberOfRepeats);
#include <ESP8266WiFi.h>
#include <PubSubClient.h>
//##include <IRremoteESP8266.h>
#include <IRremote.hpp>
#include <IRsend.hpp>

const uint16_t kIrLed = 5;  // ESP8266 GPIO pin to use. Recommended: 5 (D1).

IRsend IrSend(kIrLed);  // Set the GPIO to be used to sending the message.
//IRsend IrSend();

int numberOfRepeats = 2;
// Update these with values suitable for your network.

const char* ssid = "SSID";
const char* password = "SSIDSecret";
const char* mqtt_server = "192.168.1.25";
#define MQTT_USER  "MQTTUSER"
#define MQTT_PASSWORD "MQTTPWD"

WiFiClient espClient;
PubSubClient client(espClient);
unsigned long lastMsg = 0;
#define MSG_BUFFER_SIZE	(50)
char msg[MSG_BUFFER_SIZE];
int value = 0;

void setup_wifi() {

  delay(10);
  // We start by connecting to a WiFi network
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);

  WiFi.mode(WIFI_STA);
  WiFi.begin(ssid, password);

  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }

  randomSeed(micros());

  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
}

void callback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message arrived [");
  Serial.print(topic);
  Serial.print("] ");
  for (int i = 0; i < length; i++) {
    Serial.print((char)payload[i]);
  }
  Serial.println();

  
  if ((char)payload[0] == '1') {
      client.publish("Kinoszene/Status", "Kino wird eingeschaltet");
    //Fahre Leinwand runter
   
      Serial.println("Fahre Leinwand herunter");
      IrSend.sendPulseDistanceWidth(38, 450, 1350, 1300, 450, 450, 1350, 0x105555, 24, PROTOCOL_IS_LSB_FIRST, 13350, numberOfRepeats);
      delay(500); // mindestens 5 ms Pause nach dem Senden
      //IrSender.resume();
     
    Serial.println("Schalte Beamer ein");
      IrSend.sendNEC(0xF483, 0x4F, numberOfRepeats);
      delay(500); // mindestens 5 ms Pause nach dem Senden
         //IrSender.resume();
    
    Serial.println("Schalte Receiver ein");
      IrSend.sendNEC(0xA5, 0x1C, numberOfRepeats);
        
    //und der Gegenstelle zurück melden
    client.publish("Kinoszene/Status", "Kino eingeschaltet");
      
  } else if ((char)payload[0] == '0') {
    
     client.publish("Kinoszene/Status", "Kino wird ausgeschaltet");
     
      IrSend.sendNEC(0xA5, 0x1C, 2); //Power Code
      Serial.println("Receiver aus, wenn er an war. Sonst ist er jetzt an!");
      
      delay(500);
    
      //IrSend.resume();
      Serial.println("Schalte Beamer aus");
      IrSend.sendNEC(0xF483, 0x4E, numberOfRepeats);
      delay(1000);
      //Beamer braucht eine Bestätigung
      IrSend.sendNEC(0xF483, 0x4E, numberOfRepeats);
      
   
    //Fahre einwand hoch
      Serial.println("Fahre Leinwand hoch");
      IrSend.sendPulseDistanceWidth(38, 450, 1350, 1350, 450, 450, 1350, 0x205555, 24, PROTOCOL_IS_LSB_FIRST, 13350, numberOfRepeats);
      delay(500);// mindestens 5 ms Pause nach dem Senden
       //Ausschalten zurück melden
    client.publish("Kinoszene/Status", "Kino ausgeschaltet");
      
  }

}

void reconnect() {
  // Loop until we're reconnected
  while (!client.connected()) {
    Serial.print("Attempting MQTT connection...");
    // Create a random client ID
    String clientId = "Kinoszene";
    clientId += String(random(0xffff), HEX);
    // Attempt to connect
    if (client.connect(clientId.c_str(), MQTT_USER, MQTT_PASSWORD)) {
      Serial.println("connected");
      client.subscribe("Kinoszene/schalten");
     
          Serial.println("on");
          Serial.println("Kinoszene bereit");

  
    
 
    
     
    } else {
      Serial.print("failed, rc=");
      Serial.print(client.state());
      Serial.println(" try again in 5 seconds");
      // Wait 5 seconds before retrying
      delay(5000);
    }
  }
}

void setup() {
  Serial.begin(115200);
//  pinMode(SenderPin, OUTPUT);
  IrSend.begin(kIrLed);
  setup_wifi();
  client.setServer(mqtt_server, 1883);
  client.setCallback(callback);
 
}

void loop() {

  if (!client.connected()) {
    reconnect();
  }
  client.loop();

  unsigned long now = millis();
  if (now - lastMsg > 2000) {
    lastMsg = now;
    ++value;

  }
}

Ich stelle später ein Bild des Transmitters ein, evtl. ist der ja auch was für andere

So
ich habe noch einmal die Fernbedienung ausgelesen.
Als Sketch habe ich das Beispiel von IRRemote (Version 4.2.0) genommen

Das wird in der Konsole ausgegeben

Protocol=PulseWidth Raw-Data=0x205555 24 bits LSB first
Send with: IrSender.sendPulseDistanceWidth(38, 500, 1300, 1350, 450, 450, 1300, 0x205555, 24, PROTOCOL_IS_LSB_FIRST, <RepeatPeriodMillis>, <numberOfRepeats>);

Protocol=PulseWidth Repeat gap=13350us Raw-Data=0x205555 24 bits LSB first

Space of 13350 us between two detected transmission is smaller than the minimal gap of 15000 us known for implemented protocols like NEC, Sony, RC% etc..
But it can be OK for some yet unsupported protocols, and especially for repeats.
If you get unexpected results, try to increase the RECORD_GAP_MICROS in IRremote.h.

Ich werde versuchen das Problem zu lösen und hier dann posten, es wird sicher der ein oder andere sich ebenfalls mit dem Senden von Befehlen rumschlagen.

Als Transmitter kommt der "seeed grove ir emitter" zum Einsatz.

zu finden unter Grove - Infrared Emitter

A little bit late, but:

Check README, its circuit diagram. You need a transistor in order to provide more current to IR led.

This topic was automatically closed 180 days after the last reply. New replies are no longer allowed.