实验:实现水位监测并发送数据到网页(数模转换-无线通信)
续:
1-3的具体过程已经在前一章节《Arduino 开发-基于 ESP8266+湿度传感器收集湿度数据》有阐述,在这里不再作讲解,可前往我的主页查看。
对比上一章节的内容,此章节多了一步通过 ESP8266 模块的 WIFI 连接并上传到网页进行显示的步骤。
代码以及上传方式有变化。
1.无线网络连接(建立在前一章节的1-3之后)
编译并上传,之后按下复位键连接成功会在端口监视器中显示以下信息:

2.网页显示
粘贴复制的 IP 地址后回车,会显示以下内容:

3.进阶
如果不断往器皿内不断加水,水位数据会不断上升
4.附代码
#include <ESP8266WiFi.h>
#include <ESP8266WebServer.h>
int value = 0;
float WaterLevel;
const char* ssid = "HUAWEIP50";
const char* password = "11223344";
ESP8266WebServer server(80);
void setup() {
Serial.begin(115200);
delay(100);
Serial.println("Connecting to ");
Serial.println(ssid);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(1000);
Serial.print(".");
}
Serial.println("");
Serial.println("WiFi connected..!");
Serial.print("Got IP: "); Serial.println(WiFi.localIP());
server.on("/", handle_OnConnect);
server.onNotFound(handle_NotFound);
server.begin();
Serial.println("HTTP server started");
}
void loop() {
server.handleClient();
}
void handle_OnConnect() {
WaterLevel =(analogRead(A0)*100)/1024;
server.send(200, "text/html", SendHTML(WaterLevel));
}
void handle_NotFound(){
server.send(404, "text/plain", "Not found");
}
String SendHTML(float WaterLevelstat){
String ptr = "<!DOCTYPE html> <html>\n";
ptr +="<head> <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, user-scalable=no\">\n";
ptr +="<link href=\"https://fonts.googleapis.com/css?family=Open+Sans:300,400,600\" rel=\"stylesheet\">\n";
ptr +="<meta charset=\"UTF-8\">\n";
ptr +="<title>智能水位计</title>\n";
ptr +="<style>html { font-family: 'Open Sans', sans-serif; display: block; margin: 0px auto; text-align: center;color: #333333;}\n";
ptr +="body{margin-top: 50px;}\n";
ptr +="h1 {margin: 50px auto 30px;}\n";
ptr +=" .wd {margin: 50px auto 30px;width: auto;color: #f39c12}\n";
ptr +=" .wd1 {margin: 50px auto 30px;width: auto;color: #3498db}\n";
ptr +=".side-by-side{display: inline-block;vertical-align: middle;position: relative;}\n";
ptr +=".WaterLevel-text{font-weight: 600;padding-left: 15px;font-size: 19px;width: 160px;text-align: left;}\n";
ptr +=".WaterLevel{font-weight: 300;font-size: 60px;color: #3498db;}\n";
ptr +=".superscript{font-size: 17px;font-weight: 600;position: absolute;right: -20px;top: 15px;}\n";
ptr +=".data{padding: 10px;}\n";
ptr +="</style>\n";
ptr +="</head>\n";
ptr +="<body>\n";
ptr +="<div id=\"webpage\">\n";
ptr +="<h1>水位检测系统</h1>\n";
ptr +="<div class=\"data\">\n";
ptr +="</div>\n";
ptr +="<span class=\"superscript\">°C</span></div>\n";
ptr +="</div>\n";
ptr +="<div class=\"data\">\n";
ptr +="</div>\n";
ptr +="<div class=\"side-by-side WaterLevel-text\">当前水位:</div>\n";
ptr +="<div class=\"side-by-side WaterLevel\">";
ptr +=(int)WaterLevelstat;
ptr +="<span class=\"superscript\">%</span></div>\n";
ptr +="</div>\n";
ptr +="</div>\n";
ptr +="</body>\n";
ptr +="</html>\n";
return ptr;
}
本人是一名物联网应用技术专业的学生,制作不易,给大家分享嵌入式开发教程,觉得还不错可以关注我,后面会持续更新实战教程。