ESP32 开发笔记(四)LVGL控件学习 LED 灯控件

先看效果,创建三个LED控件,第一个关状态,第二个可调,第三个一开关,创建一个滑块控件来控制第二个LED高度

开发板购买链接https://item.taobao.com/item.htm?spm=a2oq0.12575281.0.0.50111deb2Ij1As&ft=t&id=626366733674

一、开发板简介

二、开发环境搭建 windows

三、基础示例

四、LVGL控件使用示例

    LVGL_Arc_Test                                  圆弧指示器通过触摸动态改变值
    LVGL_Bar_Test                                  通过动画方式动态演示Bar进度条的使用方法
    LVGL_Button_Test                             通过5种不同动态效果的按钮学习按钮的创建与使用
    LVGL_ButtonMatrix_Test                   创建一个计算器布局来演示矩阵按钮控件的使用
    LVGL_Calendar_Test                         日历控件的创建和使用
   LVGL_Canvas_Test                          透明画布和画一个圆角过渡色矩形旋转角度学习画布的使用
    LVGL_Chart_Test                               通过创建三个不同风格的图表来学习图表控件的使用
    LVGL_Checkbox_Test                        学习复选框控件的创建和使用
    LVGL_ColorPicker_Test                     创建一个颜色选择器并动态显示当前颜色的RGB值
    LVGL_Container_Test                        在容器控件上动态创建三个文本标签
    LVGL_Drop_down_List_Test              创建三个不同类型的下拉选择控件
    LVGL_Gauge_Test                             创建一个动态仪表和静态多指针仪表
    LVGL_Image_Test                              通过四个滑动条控制图片颜色的变化学习图像控件的使用
    LVGL_ImageButton_Test                  创建一个图片背景的图像按钮
    LVGL_Keyboard_Test                       通过一个文本输入框控件还学习键盘控件的调用关闭设置
    LVGL_Label_Test                              创建颜色可变,长文本滚动,带阴影3D效果三个标签控件
    LVGL_LED_Test                                创建三个LED,学习LED控件的调光,颜色,开关的设置
    LVGL_Line_Test                                通过二维数组创建一段折线来演示线控件的使用
    LVGL_LineMeter_Test                      创建两个不同的线段弧形指示器动态展示数据
    LVGL_List_Test                                 创建一个带图标的列表控件
    LVGL_MessageBox_Test                  创建一个带按钮的消息框控件
    LVGL_ObjectMask_Test                    创建一个变幻色的文本学习蒙版遮罩效果
    LVGL_Page_Test                            学习页面控件的使用
    LVGL_Roller_Test                           通过示例学习滑动列表选择器控件
    LVGL_Slider_Test                           创建一个单向和一个双向滑动条控件
    LVGL_Spinbox_Test                        学习微调控件的使用
    LVGL_Spinner_Test                        创建三个不同的环形加载器
    LVGL_Switch_Test                          创建两个不同的开关控件
    LVGL_Table_Test                            创建一个简单的表格
    LVGL_Tabview_Test                       实现三页的页面切换学习Tabview控件
    LVGL_Textarea_Test                       长按实现打字机效果的Textarea控件
    LVGL_Tileview_Test                        实现四面环形触摸切换的Tileview控件
    LVGL_Window_Test                        创建一个窗口,带设置子窗口学习窗口控件的使用

LED(lv_led):

LED是矩形(或圆形)对象。它的亮度可以调节。亮度降低时,LED的颜色会变暗。

零件和样式

LED只有一个主要部分,称为 LV_LED_PART_MAIN ,它使用所有典型的背景样式属性。

用法

亮度

可以使用 lv_led_set_bright(led, bright) 设置它们的亮度。亮度应介于0(最暗)和255(最亮)之间。

切换

使用 lv_led_on(led) 和 lv_led_off(led) 将亮度设置为预定义的ON或OFF值。 lv_led_toggle(led) 在ON和OFF状态之间切换。

事件

仅支持 通用事件

按键处理

对象类型不处理任何键。

 

可以使用ESP32的Web服务器和GPIO控制来实现Web控制LED。 以下是一个简单的示例代码: ```c++ #include <WiFi.h> #include <WebServer.h> const char* ssid = "your_SSID"; const char* password = "your_PASSWORD"; WebServer server(80); const int ledPin = 2; //GPIO 2 void setup() { Serial.begin(115200); pinMode(ledPin, OUTPUT); WiFi.begin(ssid, password); while (WiFi.status() != WL_CONNECTED) { delay(1000); Serial.println("Connecting to WiFi..."); } Serial.println("Connected to WiFi"); server.on("/", handleRoot); server.on("/on", handleOn); server.on("/off", handleOff); server.begin(); Serial.println("HTTP server started"); } void loop() { server.handleClient(); } void handleRoot() { server.send(200, "text/html", "<h1>ESP32 LED Control</h1><p><a href=\"/on\">Turn On</a></p><p><a href=\"/off\">Turn Off</a></p>"); } void handleOn() { digitalWrite(ledPin, HIGH); server.send(200, "text/html", "<h1>LED is On</h1><p><a href=\"/\">Back</a></p>"); } void handleOff() { digitalWrite(ledPin, LOW); server.send(200, "text/html", "<h1>LED is Off</h1><p><a href=\"/\">Back</a></p>"); } ``` 在这个示例中,ESP32会连接到您的Wi-Fi网络,并启动一个Web服务器。您可以通过访问ESP32的IP地址来访问Web页面。 Web页面包括两个按钮:“Turn On”和“Turn Off”。单击这些按钮会向ESP32发送请求,并在LED引脚上设置相应的电平。 要运行此示例,请将代码中的“your_SSID”和“your_PASSWORD”替换为您的Wi-Fi网络的凭据,并将LED引脚号更改为您连接LED的引脚。然后,将代码上传到ESP32,并通过串行监视器查看ESP32连接到Wi-Fi网络的状态。最后,通过访问ESP32的IP地址来访问Web页面,并控制LED的状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值