Arduino 开发-基于 ESP8266+湿度传感器收集湿度数据上传网页

96 阅读3分钟

实验:实现水位监测并发送数据到网页(数模转换-无线通信)

续:
1-3的具体过程已经在前一章节《Arduino 开发-基于 ESP8266+湿度传感器收集湿度数据》有阐述,在这里不再作讲解,可前往我的主页查看。
对比上一章节的内容,此章节多了一步通过 ESP8266 模块的 WIFI 连接并上传到网页进行显示的步骤。
代码以及上传方式有变化。

1.无线网络连接(建立在前一章节的1-3之后)

编译并上传,之后按下复位键连接成功会在端口监视器中显示以下信息:

image.png

2.网页显示

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

image.png

3.进阶

如果不断往器皿内不断加水,水位数据会不断上升

4.附代码

#include <ESP8266WiFi.h>
#include <ESP8266WebServer.h>

//定义ADC(模拟至数字转换器)读取的值
int value = 0;//读取的值

float WaterLevel;

// 上传完毕之后一定要按下 ESP8266 的复位按钮进行重置
// 正在连接 WIFI ,将 GOT IP 进行复制粘贴到自己的浏览器中
// 添加一些水来增加水位看看数据有没有变化
// 在网页中刷新的速度取决于你的热点网速
// 今天的实验演示到此结束,谢谢大家


// 自己的电脑一定要连接与自己输入的同一个无线热点才可以
const char* ssid = "HUAWEIP50";  //输入你的WIFI名称
const char* password = "11223344";  //输入你的wifi密码

ESP8266WebServer server(80);//建立80端口的server服务


void setup() {  
  Serial.begin(115200);//设置串口波特率为115200
  delay(100);


 //以下为串口打印wifi连接信息
  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;
   }
   

本人是一名物联网应用技术专业的学生,制作不易,给大家分享嵌入式开发教程,觉得还不错可以关注我,后面会持续更新实战教程。