给我些一个网页控制esp8266调光的,网页里有个拖动条,拖动条最左边灯最暗,拖到最右边灯最亮
时间: 2024-03-04 08:53:45 浏览: 101
好的,以下是一个简单的网页控制 ESP8266 调光的示例代码,其中使用了 `<input type="range">` 标签来实现拖动条的功能,代码中使用了 jQuery 库和 AJAX 技术来实现网页和 ESP8266 板之间的通信。
HTML 代码:
```html
<!DOCTYPE html>
<html>
<head>
<title>ESP8266 调光控制</title>
<meta charset="UTF-8">
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
</head>
<body>
<h1>ESP8266 调光控制</h1>
<p>使用下面的拖动条来调节 LED 灯的亮度:</p>
<input type="range" min="0" max="100" value="0" id="brightness">
<script>
$(function() {
// 当拖动条的值发生变化时,发送 AJAX 请求到 ESP8266 板
$('#brightness').on('input', function() {
var brightness = $(this).val();
$.ajax({
url: 'http://192.168.1.100/brightness',
method: 'POST',
data: { brightness: brightness },
dataType: 'json',
success: function(response) {
console.log(response);
},
error: function(xhr, status, error) {
console.log('Error:', error);
}
});
});
});
</script>
</body>
</html>
```
ESP8266 代码:
```c++
#include <ESP8266WiFi.h>
#include <ESP8266WebServer.h>
#include <ArduinoJson.h>
const char* ssid = "your_ssid";
const char* password = "your_password";
ESP8266WebServer server(80);
int brightness = 0;
void handleBrightness() {
if (server.method() == HTTP_POST) {
String body = server.arg("plain");
StaticJsonDocument<256> doc;
DeserializationError error = deserializeJson(doc, body);
if (!error) {
brightness = doc["brightness"];
server.send(200, "application/json", "{\"status\": \"ok\"}");
} else {
server.send(400, "text/plain", "Bad Request");
}
} else {
server.send(405, "text/plain", "Method Not Allowed");
}
}
void handleRoot() {
String html = "<html><body>";
html += "<h1>ESP8266 调光控制</h1>";
html += "<p>当前亮度:" + String(brightness) + "</p>";
html += "</body></html>";
server.send(200, "text/html", html);
}
void setup() {
Serial.begin(9600);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(1000);
Serial.println("Connecting to WiFi...");
}
Serial.println("Connected to WiFi");
Serial.print("IP address: ");
Serial.println(WiFi.localIP());
server.on("/brightness", handleBrightness);
server.on("/", handleRoot);
server.begin();
}
void loop() {
server.handleClient();
analogWrite(D1, map(brightness, 0, 100, 0, 1023));
}
```
这个示例代码中,网页使用了一个 `<input type="range">` 标签来实现拖动条的功能,用户可以通过拖动条来调节 LED 灯的亮度。当拖动条的值发生变化时,网页会通过 AJAX 发送 POST 请求到 ESP8266 板,请求的数据包含了 LED 灯的亮度值。ESP8266 板会根据亮度值来控制 LED 灯的亮度,并将当前亮度值返回给网页。
注意,这个示例代码中使用了 ArduinoJson 库来解析 POST 请求的数据,需要在 Arduino IDE 中安装该库。
阅读全文