esp8266控制继电器问题(通电瞬间继电器吸合断开一次)
本帖最后由 roohom 于 2020-3-4 15:06 编辑想问一下各位developer,我是用esp8266控制继电器,默认通电后是关状态,可是我发现,当我通电的瞬间,继电器会吸合一次并迅速断开,当我用它控制灯泡时,灯泡也就会立刻闪一下,请问如何修改代码才能让通电后继电器不迅速得吸合又断开呢?
代码如下:
#define BLINKER_WIFI
#define BLINKER_MIOT_OUTLET //小爱同学
#include <Blinker.h>
char auth[] = "";
char ssid[] = "";
char pswd[] = "";
#define LED 0 //0对应GPIO02对应GPIO2
bool oState = false;
BlinkerButton Button1("btn-abc");
//按下按键即会执行该函数
void button1_callback(const String & state)
{
digitalWrite(LED, !digitalRead(LED));
BLINKER_LOG("get button state: ", state);
Button1.print(state);
if (state == BLINKER_CMD_ON)
{
Button1.text("已开启");
Button1.print("on");
}
else if (state == BLINKER_CMD_OFF)
{
Button1.text("已关闭");
Button1.print("off");
}
}
void heartbeat()
{
if(oState)
{
Button1.text("已开启");
Button1.print("on");
}
else{
Button1.text("已关闭");
Button1.print("off");
}
}
void miotPowerState(const String & state)
{
BLINKER_LOG("need set power state: ", state);
if (state == BLINKER_CMD_ON) {
digitalWrite(LED, LOW);
BlinkerMIOT.powerState("on");
BlinkerMIOT.print();
Button1.text("已开启");
Button1.print("on");
oState = true;
} else if (state == BLINKER_CMD_OFF) {
digitalWrite(LED, HIGH);
BlinkerMIOT.powerState("off");
BlinkerMIOT.print();
Button1.text("已关闭");
Button1.print("off");
oState = false;
}
}
void miotQuery(int32_t queryCode)
{
BLINKER_LOG("MIOT Query codes: ", queryCode);
switch (queryCode)
{
case BLINKER_CMD_QUERY_ALL_NUMBER :
BLINKER_LOG("MIOT Query All");
BlinkerMIOT.powerState(oState ? "on" : "off");
BlinkerMIOT.print();
break;
case BLINKER_CMD_QUERY_POWERSTATE_NUMBER :
BLINKER_LOG("MIOT Query Power State");
BlinkerMIOT.powerState(oState ? "on" : "off");
BlinkerMIOT.print();
break;
default :
BlinkerMIOT.powerState(oState ? "on" : "off");
BlinkerMIOT.print();
break;
}
}
void dataRead(const String & data)
{
BLINKER_LOG("Blinker readString: ", data);
Blinker.vibrate();
uint32_t BlinkerTime = millis();
Blinker.print("millis", BlinkerTime);
}
void setup()
{
Serial.begin(115200);
BLINKER_DEBUG.stream(Serial);
pinMode(LED, OUTPUT);
digitalWrite(LED, HIGH);
Blinker.begin(auth, ssid, pswd);
Blinker.attachData(dataRead);
Button1.attach(button1_callback);
BlinkerMIOT.attachPowerState(miotPowerState);
BlinkerMIOT.attachQuery(miotQuery);
Blinker.attachHeartbeat(heartbeat);
BLINKER_DEBUG.debugAll();
}
void loop()
{
Blinker.run();
}
今天继续研究这个问题,原来这是一个继电器抖动问题,就是在esp8266上电瞬间(大约是350ms到500ms),esp8266会在GPIO口给出一个高电平(低电平),并且这是硬件电路问题(官方SDK问题?),只需要对电路另加改造就可以避免。
参考文章见:
https://blog.csdn.net/sxyandapp/article/details/78330878
https://blog.csdn.net/pillarpeng/article/details/52119657?depth_1-utm_source=distribute.pc_relevant.none-task&utm_source=distribute.pc_relevant.none-task #define BLINKER_WIFI
#define BLINKER_MIOT_LIGHT
#include <Blinker.h>
char auth[] = "****";//设备key
char ssid[] = "***";//路由器wifi ssid
char pswd[] = "123456780";//路由器wifi 密码
// 新建组件对象
BlinkerButton Button1("btn-pjl");//定义按钮键名
// 按下BlinkerAPP按键即会执行该函数
void button1_callback(const String & state) {
BLINKER_LOG("get button state: ", state);
digitalWrite(LED_BUILTIN, !digitalRead(LED_BUILTIN));
Blinker.vibrate();
}
//小爱电源类操作的回调函数:
//当小爱同学向设备发起控制, 设备端需要有对应控制处理函数
void miotPowerState(const String & state)
{
BLINKER_LOG("need set power state: ", state);
if (state == BLINKER_CMD_ON) {
digitalWrite(LED_BUILTIN, HIGH);
BlinkerMIOT.powerState("on");
BlinkerMIOT.print();
}
else if (state == BLINKER_CMD_OFF) {
digitalWrite(LED_BUILTIN, LOW);
BlinkerMIOT.powerState("off");
BlinkerMIOT.print();
}
}
void setup() {
// 初始化串口,并开启调试信息,调试用可以删除
Serial.begin(115200);
BLINKER_DEBUG.stream(Serial);
// 初始化IO
pinMode(LED_BUILTIN, OUTPUT);
digitalWrite(LED_BUILTIN, HIGH);
// 初始化blinker
Blinker.begin(auth, ssid, pswd);
Button1.attach(button1_callback);
//小爱同学务必在回调函数中反馈该控制状态
BlinkerMIOT.attachPowerState(miotPowerState);
//注册回调函数
}
void loop() {
Blinker.run();
} #define BLINKER_WIFI
#define BLINKER_MIOT_LIGHT
#include <Blinker.h>
char auth[] = "2b1f***b";//设备key
char ssid[] = "mi";//路由器wifi ssid
char pswd[] = "1***80";//路由器wifi 密码
// 新建组件对象
BlinkerButton Button1("btn-pjl");//定义按钮键名
// 按下BlinkerAPP按键即会执行该函数
void button1_callback(const String & state) {
BLINKER_LOG("get button state: ", state);
digitalWrite(LED_BUILTIN, !digitalRead(LED_BUILTIN));
Blinker.vibrate();
}
//小爱电源类操作的回调函数:
//当小爱同学向设备发起控制, 设备端需要有对应控制处理函数
void miotPowerState(const String & state)
{
BLINKER_LOG("need set power state: ", state);
if (state == BLINKER_CMD_ON) {
digitalWrite(LED_BUILTIN, HIGH);
BlinkerMIOT.powerState("on");
BlinkerMIOT.print();
}
else if (state == BLINKER_CMD_OFF) {
digitalWrite(LED_BUILTIN, LOW);
BlinkerMIOT.powerState("off");
BlinkerMIOT.print();
}
}
void setup() {
// 初始化串口,并开启调试信息,调试用可以删除
Serial.begin(115200);
BLINKER_DEBUG.stream(Serial);
// 初始化IO
pinMode(LED_BUILTIN, OUTPUT);
digitalWrite(LED_BUILTIN, HIGH);
// 初始化blinker
Blinker.begin(auth, ssid, pswd);
Button1.attach(button1_callback);
//小爱同学务必在回调函数中反馈该控制状态
BlinkerMIOT.attachPowerState(miotPowerState);
//注册回调函数
}
void loop() {
Blinker.run();
} 参考上面的自己修改一下就可以了 你这个恰恰和我的相反。我就是要这个效果! z01228 发表于 2020-3-1 09:21
#define BLINKER_WIFI
#define BLINKER_MIOT_LIGHT
#include
这个与我的不同点在哪呢:lol 我看楼主的代码,继电器应该是低电平吸合的,我没仔细研究过上电时引脚的电平,按照你说的应该就是模块上电时候输出的低电平,然后加载程序后继电器又复位了。要不你试试在SETUP里面加个 digitalWrite(LED, HIGH);试试,不过感觉模块上电时候还没读程序,要不你还是换个高电平触发的继电器?再不然,你试试正级加个电阻引导对应控制继电器的引脚?估计默认上电就可以给高电平。 z01228 发表于 2020-3-1 09:22
参考上面的自己修改一下就可以了
你这个继电器是高电平吸合还是低电平吸合呢 我理解错误你的问题了 你的问题原因是通电瞬间继电器吸合断开一次。这个是因为在上电的一瞬间单片机io口的电平不稳定造成的你加一个上拉电阻应该就可以解决问题了
在5V器件的15K以下的上拉电阻都是没问题的、3.3V的话一般4.7K~10K都是比较常用的
页:
[1]
2