LVGL开发教程-按钮Button

2024-06-19 23:12
文章标签 教程 开发 按钮 lvgl button

本文主要是介绍LVGL开发教程-按钮Button,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

系列文章目录

知不足而奋进 望远山而前行


目录

系列文章目录

文章目录

前言

1. 普通Button

2.可选中Button

3.按钮事件处理

总结


前言

在图形用户界面(GUI)开发中,按钮(Button)是用户与程序交互的重要组件之一。通过按钮,用户可以触发各种操作和事件,从而实现对应用程序的控制和导航。本文将介绍如何使用 LittlevGL 库创建普通按钮和可选中按钮,并实现它们的事件处理功能。


hi按钮Button是用户和程序的一种交互手段。

1. 普通Button

创建Button:

lv_obj_t * lv_btn_create(lv_obj_t * parent)

添加事件处理:

struct _lv_event_dsc_t * lv_obj_add_event_cb(lv_obj_t * obj, lv_event_cb_t event_cb, lv_event_code_t filter,void * user_data)

参数1:按钮控件

参数2:回调函数

参数3:处理的事件

参数4:传递用户数据

示例代码:

void first_screen(){// 创建按钮lv_obj_t* btn = lv_btn_create(lv_scr_act());lv_obj_align(btn,LV_ALIGN_CENTER,0,0);// 创建按钮上的文本lv_obj_t* label = lv_label_create(btn);lv_label_set_text(label,"button");
}

2.可选中Button

void first_screen(){lv_obj_t * label;lv_obj_t * btn2 = lv_btn_create(lv_scr_act());lv_obj_align(btn2, LV_ALIGN_CENTER, 0, 0);//设置按钮可以被选中lv_obj_add_flag(btn2, LV_OBJ_FLAG_CHECKABLE);label = lv_label_create(btn2);lv_label_set_text(label, "Toggle");
}

3.按钮事件处理

普通按钮需要处理点击事件,可选中按钮需要处理选中状态切换事件。

添加事件处理:

struct _lv_event_dsc_t * lv_obj_add_event_cb(lv_obj_t * obj, lv_event_cb_t event_cb, lv_event_code_t filter,void * user_data)

参数1:需要进行事件处理的object

参数2:事件处理回调函数

参数3:需要处理的事件

参数4:传递用户数据

普通按钮点击事件:

//事件回调函数
void event_handler(lv_event_t * e){int code = lv_event_get_code(e);lv_obj_t* obj = lv_event_get_target(e);if(code == LV_EVENT_CLICKED){lv_obj_t* label = lv_event_get_user_data(e);lv_label_set_text(label,"itheima");printf("clicked\n");}
}void first_screen(){lv_obj_t * label;lv_obj_t * btn1 = lv_btn_create(lv_scr_act());//给按钮设置点击事件处理lv_obj_add_event_cb(btn1, event_handler, LV_EVENT_CLICKED, NULL);...
}

可选中Button事件处理:

//事件回调
void event_handler(lv_event_t * e){lv_event_code_t code = lv_event_get_code(e);if(code==LV_EVENT_VALUE_CHANGED){printf("toggled btn\n");}
}void first_screen(){lv_obj_t * label;lv_obj_t * btn2 = lv_btn_create(lv_scr_act());lv_obj_add_event_cb(btn2, event_handler, LV_EVENT_VALUE_CHANGED, NULL);...
}

区分多个按钮事件:

多个按钮点击事件使用通过同一个回调函数处理时,可以在添加事件时通过user_data参数区分

void event_handler(lv_event_t * e){lv_event_code_t code = lv_event_get_code(e);char *d = (char *)lv_event_get_user_data(e);if(code==LV_EVENT_CLICKED){if(strcmp(d,"btn1")==0){printf("click data1\n");}else if(strcmp(d,"btn2")==0){printf("click data2\n");}}
}void first_screen(){lv_obj_t * label;char *data1 = "btn1";char *data2 = "btn2";lv_obj_t * btn1 = lv_btn_create(lv_scr_act());...lv_obj_t * btn2 = lv_btn_create(lv_scr_act());lv_obj_add_event_cb(btn2, event_handler, LV_EVENT_CLICKED, data2);...
}

总结

本文详细讨论了在 LittlevGL 中创建和处理按钮的方法。首先,通过 lv_btn_create 函数创建了普通按钮和可选中按钮,并演示了如何在按钮上添加文本。其次,通过 lv_obj_add_event_cb 函数为按钮添加事件处理函数,区分了普通按钮的点击事件和可选中按钮的状态切换事件。最后,展示了如何通过 user_data 参数区分多个按钮的事件处理,使得同一事件处理函数可以应用于不同按钮,并根据需要执行不同的逻辑操作。通过本文的学习,读者可以掌握在 LittlevGL 中有效管理和操作按钮的关键技能,从而提升 GUI 应用程序的交互性和用户体验。

这篇关于LVGL开发教程-按钮Button的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1076417

相关文章

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

SpringBoot连接Redis集群教程

《SpringBoot连接Redis集群教程》:本文主要介绍SpringBoot连接Redis集群教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 依赖2. 修改配置文件3. 创建RedisClusterConfig4. 测试总结1. 依赖 <de

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根