您好,欢迎回来。
这是一款基于 NODEMCU ESP8266 板和 6 通道继电器的家庭自动化板。
该板通过任何浏览器访问其 Web 应用程序在本地控制,它目前可以控制 6 种不同的输出,但我们可以添加更多,并且很容易更改额外输出的代码。
该项目的目标是制作一个简单易用的家庭自动化系统,任何人都可以通过几个简单的步骤来制作和学习。
让我们开始吧。
以下是该项目中使用的东西-
我们首先准备面包板设置,该设置由与 ESP8266 Nodemcu 板的 D0、D1、D2、D3、D4 和 D5 引脚连接的六个 LED 组成。
正在使用 NodeMCU,但任何 ESP8266 板都可以在这里使用,我们甚至可以通过使用最小的 ESP8266 设置来准备使用 ESP12F 或 12E 模块的设置。
完成面包板设置后,我们为该项目准备主 PCB,该项目将在定制 PCB 面包板上制作。
PCB 面包板是我为快速原型工作而开发的定制板。它由与普通面包板相同的形状因子排列的孔组成。
每个孔距每个孔 2.54 毫米,就像物理面包板和插头引脚中的一样。
PCBWAY 制造了这个,它的质量非常好。
这是控制交流甚至直流负载的主要工作的组件,即 6 通道继电器模块。
6路继电器输出模块触点容量为10A 250V,因此可以处理2500W阈值以下的任何负载。
输入使用 LOW 信号工作并打开继电器,使用 HIGH 信号关闭继电器。
它包含 6 个红色 LED,每个 LED 都与一个光耦合器连接,该光耦合器控制 N 沟道晶体管的栅极,该晶体管然后打开或关闭继电器。
每个继电器都与相同的设置连接,该设置由一个光耦和控制继电器的晶体管组成。
我已经在万用表的帮助下按照轨迹为这个继电器模块创建了一个示意图,您可以使用这个示意图来重新制作您的继电器模块。
至于采购继电器模块,我使用PCBWAY 的礼品店订购传感器。
https://www.pcbway.com/project/gifts_detail/6_Channel_DC_5V_Relay_Module_Relay_Expansion_Board.html
除了 PCB Services,PCBWAY 也有专门的元件商店。
PCBWAY GIFTSHOP 是一个在线市场,我们可以从中采购所有主要的电子产品,如 Arduino 板、Raspberry Pi 板、模块、传感器等。
PCBWAY 有这个系统,可以让我们通过豆子从他们的礼品店购买任何东西,豆子就像一种可兑换的货币或优惠券,我们通过在 PCBWAY 上下订单或在社区中分享您的项目来获得豆子。
从这里检查 PCBWAY 以获得出色的 PCB 服务 - https://www.pcbway.com/
这是连接 ESP8266 NodeMCU 板和 6 通道继电器模块的示意图。
这是用于控制家庭自动化设置的主要 WEB PAGE 或 WEB 应用程序,此网络应用程序是完全定制的,完全由一个草图制成,无需使用任何第三方工具。
#include
// Replace with your network credentials
const char *ssid = "add your ssid";
const char *password = "add your password yo";
// Set web server port number to 80
WiFiServer server(80);
// Variable to store the HTTP request
String header;
// Auxiliar variables to store the current output state
String output1State = "off";
String output2State = "off";
String output3State = "off";
String output4State = "off";
String output5State = "off";
// Assign output variables to GPIO pins
const int output1 = 16; //D0
const int output2 = 5; //D1
const int output3 = 4; //D2
const int output4 = 0; //D3
const int output5 = 2; //D4
void setup() {
Serial.begin(115200);
// Initialize the output variables as outputs
pinMode(output1, OUTPUT);
pinMode(output2, OUTPUT);
pinMode(output3, OUTPUT);
pinMode(output4, OUTPUT);
pinMode(output5, OUTPUT);
// Set outputs to LOW
digitalWrite(output1, LOW);
digitalWrite(output2, LOW);
digitalWrite(output3, LOW);
digitalWrite(output4, LOW);
digitalWrite(output5, LOW);
// Connect to Wi-Fi network with SSID and password
Serial.print("Connecting to ");
Serial.println(ssid);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
Serial.print(".");
}
// Print local IP address and start web server
Serial.println("");
Serial.println("WiFi connected.");
Serial.println("IP address: ");
Serial.println(WiFi.localIP());
server.begin();
}
void loop(){
WiFiClient client = server.available(); // Listen for incoming clients
if (client) { // If a new client connects,
Serial.println("New Client."); // print a message out in the serial port
String currentLine = ""; // make a String to hold incoming data from the client
while (client.connected()) { // loop while the client's connected
if (client.available()) { // if there's bytes to read from the client,
char c = client.read(); // read a byte, then
Serial.write(c); // print it out the serial monitor
header += c;
if (c == '\n') { // if the byte is a newline character
// if the current line is blank, you got two newline characters in a row.
// that's the end of the client HTTP request, so send a response:
if (currentLine.length() == 0) {
// HTTP headers always start with a response code (e.g. HTTP/1.1 200 OK)
// and a content-type so the client knows what's coming, then a blank line:
client.println("HTTP/1.1 200 OK");
client.println("Content-type:text/html");
client.println("Connection: close");
client.println();
// turns the GPIOs on and off
if (header.indexOf("GET /1/on") >= 0) { //LOAD1
Serial.println("LOAD1 on");
output1State = "on";
digitalWrite(output1, HIGH);
} else if (header.indexOf("GET /1/off") >= 0) {
Serial.println("LOAD1 off");
output1State = "off";
digitalWrite(output1, LOW);
} else if (header.indexOf("GET /2/on") >= 0) { //LOAD2
Serial.println("LOAD2 on");
output2State = "on";
digitalWrite(output2, HIGH);
} else if (header.indexOf("GET /2/off") >= 0) {
Serial.println("LOAD2 off");
output2State = "off";
digitalWrite(output2, LOW);
} else if (header.indexOf("GET /3/on") >= 0) { //LOAD3
Serial.println("LOAD3 on");
output3State = "on";
digitalWrite(output3, HIGH);
} else if (header.indexOf("GET /3/off") >= 0) {
Serial.println("LOAD3 off");
output3State = "off";
digitalWrite(output3, LOW);
} else if (header.indexOf("GET /4/on") >= 0) { //LOAD4
Serial.println("LOAD4 on");
output4State = "on";
digitalWrite(output4, HIGH);
} else if (header.indexOf("GET /4/off") >= 0) {
Serial.println("LOAD4 off");
output4State = "off";
digitalWrite(output4, LOW);
} else if (header.indexOf("GET /5/on") >= 0) { //LOAD5
Serial.println("LOAD5 on");
output5State = "on";
digitalWrite(output5, HIGH);
} else if (header.indexOf("GET /5/off") >= 0) {
Serial.println("LOAD5 off");
output5State = "off";
digitalWrite(output5, LOW);
}
// Display the HTML web page
client.println("");
client.println("");
client.println("");
client.println("");
// Web Page Heading
client.println("HOME AUTOMATION BASIC
");
// Display current state, and ON/OFF buttons for OUTPUT1
client.println("LOAD1 - State "
+ output1State + "");
// If the output1State is off, it displays the ON button
if (output1State=="off") {
client.println("");
} else {
client.println("");
}
// Display current state, and ON/OFF buttons for OUTPUT2
client.println("LOAD2 - State "
+ output2State + "");
// If the output2State is off, it displays the ON button
if (output2State=="off") {
client.println("");
} else {
client.println("");
}
// Display current state, and ON/OFF buttons for OUTPUT3
client.println("LOAD3 - State "
+ output3State + "");
// If the output3State is off, it displays the ON button
if (output3State=="off") {
client.println("");
} else {
client.println("");
}
// Display current state, and ON/OFF buttons for OUTPUT4
client.println("LOAD4 - State "
+ output4State + "");
// If the output4State is off, it displays the ON button
if (output4State=="off") {
client.println("");
} else {
client.println("");
}
// Display current state, and ON/OFF buttons for OUTPUT5
client.println("LOAD5 - State "
+ output4State + "");
// If the output5State is off, it displays the ON button
if (output5State=="off") {
client.println("");
} else {
client.println("");
}
client.println("");
// The HTTP response ends with another blank line
client.println();
// Break out of the while loop
break;
} else { // if you got a newline, then clear currentLine
currentLine = "";
}
} else if (c != '\r') { // if you got anything else but a carriage return character,
currentLine += c; // add it to the end of the currentLine
}
}
}
// Clear the header variable
header = "";
// Close the connection
client.stop();
Serial.println("Client disconnected.");
Serial.println("");
}
}
这是我在此设置中使用的代码,它是一个简单的基于 WEB 服务器的草图,可让我们使用 WEB APP 控制五个 GPIO。
这个 Sketch 融合了经典的嵌入式 C 语言和带有一点 CSS 的 HTML。
我们通过以下几行在此草图中设置了 HTML 页面。
// Display the HTML web page
client.println("html><html>");
client.println("<head><meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">");
client.println("<link rel=\"icon\" href=\"data:,\">");
client.println("<style>html { font-family: Helvetica; display: inline-block; margin: 0px auto; text-align: center;}");
client.println(".button { background-color: #6a195b; border: none; color: white; padding: 16px 40px;");
client.println("text-decoration: none; font-size: 30px; margin: 2px; cursor: pointer;}");
client.println(".button2 {background-color: #a82890;}style>head>");
// Web Page Heading
client.println("<body><h1>HOME AUTOMATION BASICh1>");
这个草图比较容易理解,我们有 5 个输出,它们在草图开始时声明并设置为 LOW 状态。
const int output1 = 16; //D0
const int output2 = 5; //D1
const int output3 = 4; //D2
const int output4 = 0; //D3
const int output5 = 2; //D4
digitalWrite(output1, LOW);
digitalWrite(output2, LOW);
digitalWrite(output3, LOW);
digitalWrite(output4, LOW);
digitalWrite(output5, LOW);
当按下 HTML 按钮时,每个 GPIO 都由下面的行触发。
// turns the GPIOs on and off
if (header.indexOf("GET /1/on") >= 0) { //LOAD1
Serial.println("LOAD1 on");
output1State = "on";
digitalWrite(output1, HIGH);
} else if (header.indexOf("GET /1/off") >= 0) {
Serial.println("LOAD1 off");
output1State = "off";
digitalWrite(output1, LOW);
请注意,此设置仅适用于 ESP8266 和您在同一网络上浏览 APP 的设备。(本地网络运营)
这是结果,如您所见,该系统正在运行。
每当我们通过 WEB APP 切换继电器时,每个继电器模块顶部都有一个 LED 指示灯会打开和关闭。
在开始进行此设置之前,请确保佩戴适当的绝缘橡胶手套,并在插入交流电源后尽量不要触摸交流侧。
此设置有效,现在我们可以将其添加到我们家中的 MCB 盒中,以控制特定区域或任何控制至少 6 个光输出的照明开关附近。
它的工作方式也很简单,继电器就像物理开关,我们可以将它们与任何光源或输出串联添加。通过将 RELAY 的状态更改为 HIGH 或 LOW,它可以断开或连接电路并控制与其连接的负载。
此设置使用带有外部 5V 电源的 NodeMCU 板。
理想情况下,板载 240V AC 至 5V 1A DC 转换器以及通过单线轻松连接的负载输出。NodeMCU 可以替换为基于最小 ESP12F 的设置,该设置将在相同的拓扑中实现自己的继电器模块板。这就是我将在这个项目的第 2 版中做的事情。
这就是今天的内容,如果您在设置此项目时遇到任何问题,请发表评论。
特别感谢 PCBWAY 提供了我在这个项目中使用的组件,检查它们以获得各种 PCB 或 PCBA 相关的服务以降低成本。
谢谢,我很快就会带着一个新项目回来。
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
全部0条评论
快来发表一下你的评论吧 !