我遇到了 Dragino LG01-S 和 Heltec WiFi LoRa 32 之间的连接问题。
WiFi LoRa 32 每 5 秒向 LG01-S 发送带有温度数据的数据包。LG01-S 不断收到数据包,但一段时间后(可能是 20 分钟,可能是 7 小时),它会收到一个与其他数据包不同的数据包。我在串行监视器中跟踪数据包,直到出现一个失败的数据包,这就是我看到它们的样子。
“失败”的数据包如下所示:
¹h260äàŽÛNR·à,ªê@��ö9AÚ�o...Œ?£ÚK;ËÍ×.Ü*!®d§" ¿'ZoL
通常它是这样的:
30.00
通常数据包的大小是 5 个字节,而失败数据包的大小是 73 个字节。
失败出现在接收器(LG01-S)中,因为在失败的数据包出现后,它只是停止接收任何数据并且根本不执行任何代码。失败后 LoRa32 继续发送数据包。
我检查了失败是否一致,但它们不是,如前所述,它们发生在不同的时间。
您可以在下面看到发送方和接收方的代码。
发件人
#include <SPI.h>
#include <LoRa.h>
#include "SSD1306.h"
#include<Arduino.h>
#include <dht.h>
SSD1306 display(0x3c, 4, 15);
#define DHTPIN 17
#define SS 18
#define RST 14
#define DI0 26
#define BAND 915E6
//create an instance of DHT sensor
dht TempSensor;
void setup()
{
pinMode(16, OUTPUT);
digitalWrite(16, LOW);
delay(50);
digitalWrite(16, HIGH);
Serial.begin(115200);
while (!Serial);
display.init();
display.flipScreenVertically();
display.setFont(ArialMT_Plain_10);
display.setTextAlignment(TEXT_ALIGN_LEFT);
display.drawString(5, 5, "LoRa Sender");
display.display();
SPI.begin(5, 19, 27, 18);
LoRa.setPins(SS, RST, DI0);
Serial.println("LoRa Sender");
if (!LoRa.begin(BAND)) {
Serial.println("Starting LoRa failed!");
while (1);
}
LoRa.setSyncWord(0xF3);
Serial.println("LoRa Initial OK!");
display.drawString(5, 20, "LoRa Initializing OK!");
display.display();
delay(2000);
}
void loop() {
double check = TempSensor.read11(DHTPIN);
Serial.println(TempSensor.temperature);
Serial.print("Sending temperature: ");
Serial.println(TempSensor.temperature);
display.clear();
display.setFont(ArialMT_Plain_16);
display.drawString(3, 5, "Sending temperature ");
display.drawString(50, 30, String(TempSensor.temperature));
display.display();
// sending packet
LoRa.beginPacket();
LoRa.print(TempSensor.temperature);
Serial.println("package sent");
LoRa.endPacket();
delay(5000);
}
接收者:
#include <SPI.h>
#include <LoRa.h>
#include <Console.h>
#include <Process.h>
#include <Bridge.h>
// Set center frequency
uint32_t freq = 915E6;
Process logdata;
int timeCounter = 0;
void setup() {
Bridge.begin(115200);
Console.begin();
Console.println("LoRa Receiver");
if (!LoRa.begin(freq)) {
Console.println("Starting LoRa failed!");
while (1);
}
LoRa.setSyncWord(0xF3);
LoRa.receive();
}
void loop() {
// try to parse packet
int packetSize = LoRa.parsePacket();
if (packetSize) {
// received a packet read packet
while (LoRa.available()) {
String TemperatureData = LoRa.readString();
Console.println(TemperatureData);
Console.println(packetSize);
//Save in db
logdata.begin("lua");
logdata.addParameter("/root/LinkTempInside.lua"); //
logdata.addParameter(String(TemperatureData)); //
logdata.run(); // run the command
// read the output of the command
while (logdata.available() > 0) {
char c = logdata.read();
}
Console.println("Data Sent");
}
}
}
感谢您的帮助。