用html写个代码用来控制esp8266无极调光

时间: 2024-01-25 09:03:30 浏览: 25
下面是一个基于 HTML、JavaScript 和 ESP8266 的无极调光控制代码示例: HTML 代码: ```html <!DOCTYPE html> <html> <head> <title>ESP8266 LED Dimmer</title> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> </head> <body> <h1>ESP8266 LED Dimmer</h1> <input type="range" min="0" max="255" value="0" id="brightness"> <script> var slider = document.getElementById("brightness"); var brightness = 0; slider.oninput = function() { brightness = this.value; sendBrightness(brightness); } function sendBrightness(value) { var xhr = new XMLHttpRequest(); xhr.open("GET", "/brightness?value=" + value, true); xhr.send(); } </script> </body> </html> ``` JavaScript 代码: ```javascript var slider = document.getElementById("brightness"); var brightness = 0; slider.oninput = function() { brightness = this.value; sendBrightness(brightness); } function sendBrightness(value) { var xhr = new XMLHttpRequest(); xhr.open("GET", "/brightness?value=" + value, true); xhr.send(); } ``` ESP8266 代码: ```c++ #include <ESP8266WiFi.h> #include <WiFiClient.h> #include <ESP8266WebServer.h> // WiFi 参数 const char* ssid = "your-ssid"; const char* password = "your-password"; // 灯控制参数 const int LED_PIN = 5; int brightness = 0; // Web 服务器 ESP8266WebServer server(80); void handleRoot() { String html = "<html><head><title>ESP8266 LED Dimmer</title></head><body>"; html += "<h1>ESP8266 LED Dimmer</h1>"; html += "<input type=\"range\" min=\"0\" max=\"255\" value=\""; html += String(brightness); html += "\" id=\"brightness\">"; html += "<script>"; html += "var slider = document.getElementById(\"brightness\");"; html += "var brightness = " + String(brightness) + ";"; html += "slider.oninput = function() {"; html += "brightness = this.value;"; html += "sendBrightness(brightness);"; html += "}"; html += "function sendBrightness(value) {"; html += "var xhr = new XMLHttpRequest();"; html += "xhr.open(\"GET\", \"/brightness?value=\" + value, true);"; html += "xhr.send();"; html += "}"; html += "</script>"; html += "</body></html>"; server.send(200, "text/html", html); } void handleBrightness() { String value = server.arg("value"); brightness = value.toInt(); analogWrite(LED_PIN, brightness); server.send(200, "text/plain", "OK"); } void setup() { // 初始化串口 Serial.begin(9600); // 连接 WiFi WiFi.begin(ssid, password); while (WiFi.status() != WL_CONNECTED) { delay(1000); Serial.println("Connecting to WiFi..."); } Serial.println("Connected to WiFi"); // 设置灯控制引脚 pinMode(LED_PIN, OUTPUT); // 启动 Web 服务器 server.on("/", handleRoot); server.on("/brightness", handleBrightness); server.begin(); Serial.println("Web server started"); } void loop() { // 处理 Web 请求 server.handleClient(); } ``` 将以上三段代码分别保存为 HTML、JavaScript 和 ESP8266 的 Arduino 代码,然后将 ESP8266 连接到电脑并烧录代码。最后,连接到 ESP8266 的 WiFi 热点,并在浏览器中输入 ESP8266 的 IP 地址,即可看到一个带有滑块控件的页面,用它来控制灯的亮度。

相关推荐

最新推荐

recommend-type

无线模块esp8266控制led灯亮灭51单片机底层程序

无线模块esp8266控制led灯亮灭51单片机底层程序,只有51单片机的程序没有控制app,使用网络调试助手可以实现手机与51单片机通讯,从而达到控制led灯的亮灭,亲测可行
recommend-type

esp8266 AT指令之建立TCP透传客户端

esp8266 AT指令之建立透传TCP客户端 TCP客户端是用于与服务器产生连接,连接后可通过MQTT 等建立通讯,然后实现万物联网。 下面大家跟着小编使用esp8266建立tcp连接吧。 连接准备 ①已经刷好固件的esp8266。若未刷...
recommend-type

ESP8266的TCP服务器连接错误解决办法

解决WIN8/WIN10下ESP8266作为客户端,电脑作为服务器,所连接失败的问题
recommend-type

ESP8266(AP模式)控制51单片机亮灯.docx

有关ESP8266型号的WiFi模块的,简单有关51的用法,希望可以帮到你
recommend-type

ESP8266实现PC与模块通讯

通过串口输入AT指令来进行设置 1. AT+CWMODE=3 //设置为服务器客户端模式 2. AT+CIPMUX=1 //设置模块允许多连接,这条命令一定要比CIPSERVER先执行 3. AT+CIPSERVER=1,8080 //开启服务器,并使用8080端口进行通信...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。