Всем доброго времени суток. Хочу организовать в комнате выключение света как через выключатель, так и через mqtt. Компоненты следующие: готовое реле 10 А с оптомуфтой и обвзякой (с Китая), esp-01s (тоже из поднебесной), блок питания 3.3 В, проходной переключатель. Соответственно на реле и на esp-01s подаю 3.3 В, реле подключаю к пину 0, через проходной переключатель на пин 2 подаю/прерываю +3.3 В (т.е. одна клемма переключателя остается пустой). Скетч залил вот этот:
Т.е. смысл какой: вносятся изменения в топик либо через клиент, либо сама ESP, когда изменяется состояние пина 2. Соответственно когда в топике происходят изменения esp щелкает релюшкой.
Проблема следующая: через клиент работает все четко, а вот через переключатель - очень странно. Логики нет. Может сработать несколько раз, может вообще не откликаться. В итоге у esp срабатывает WDT и она перезагружается. Менял местами пины (реле и переключатель) - эффекта ноль. Менял, также, скорость порта со 115200 на 9600 - аналогично...Подскажите, пожалуйста, куда еще копать? Спасибо.
C:
#include <ESP8266WiFi.h>
#include <PubSubClient.h>
const char* ssid = "ssid";
const char* password = "pass";
const char* mqtt_server = "192.168.1.10";
#define mqtt_login "login"
#define mqtt_password "pass"
#define RELAY_1 0 // Реле №1
#define BUTTON_1 2 // Кнопочный выключатель №1
#define relays_topic "Switch" // Топик реле №1
WiFiClient espClient;
PubSubClient client(espClient);
//long lastMsg = 0;
//long last_mls = millis();
char msg[50];
//int value = 0;
//int diff = 1;
boolean rState1 = false;
boolean btnPress = false;
boolean lastbtnStat = false;
void setup_wifi() {
delay(10);
// We start by connecting to a WiFi network
Serial.println();
Serial.print("Connecting to ");
Serial.println(ssid);
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') {
rState1 = true;
digitalWrite(RELAY_1, rState1);
}
else {
rState1 = false;
digitalWrite(RELAY_1, rState1);
}
}
void buttonF() {
btnPress = digitalRead(BUTTON_1);
if (btnPress != lastbtnStat){
delay(30); // защита от дребезга
btnPress = digitalRead(BUTTON_1);
if(btnPress != lastbtnStat){
rState1 = !rState1;
digitalWrite(RELAY_1, rState1);
// публикуем изменение состояния реле на брокер
client.publish(relays_topic, String(rState1).c_str(), true);
lastbtnStat = btnPress;
}
}
}
void reconnect() {
// Loop until we're reconnected
while (!client.connected()) {
Serial.print("Attempting MQTT connection...");
// Create a random client ID
String clientId = "ESP8266Client-";
clientId += String(random(0xffff), HEX);
// Attempt to connect
if (client.connect(clientId.c_str(), mqtt_login, mqtt_password)) {
Serial.println("connected");
client.subscribe(relays_topic);
} 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() {
pinMode(RELAY_1, OUTPUT); // Initialize the BUILTIN_LED pin as an output
pinMode(BUTTON_1, INPUT);
digitalWrite(RELAY_1, rState1);
Serial.begin(9600);
setup_wifi();
client.setServer(mqtt_server, 1883);
client.setCallback(callback);
lastbtnStat = digitalRead(BUTTON_1);
}
void loop() {
client.loop();
if (!client.connected()) {
reconnect();
}
buttonF();
}
Проблема следующая: через клиент работает все четко, а вот через переключатель - очень странно. Логики нет. Может сработать несколько раз, может вообще не откликаться. В итоге у esp срабатывает WDT и она перезагружается. Менял местами пины (реле и переключатель) - эффекта ноль. Менял, также, скорость порта со 115200 на 9600 - аналогично...Подскажите, пожалуйста, куда еще копать? Спасибо.