【LVGL-下拉列表部件 lv_dropdown】

2024-08-25 06:04

本文主要是介绍【LVGL-下拉列表部件 lv_dropdown】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LVGL-下拉列表部件 lv_dropdown

  • ■ LVGL-下拉列表部件 lv_dropdown
    • ■ 下拉列表部件的组成
    • ■ 添加选项
    • ■ 获取当前选中的选项
    • ■ 设置列表展开方向
    • ■ 设置下拉列表图标
    • ■ 设置列表常显文本
    • ■ 打开、开闭下拉列表
    • ■ 下拉列表部件的 API 函数

■ LVGL-下拉列表部件 lv_dropdown

在这里插入图片描述

■ 下拉列表部件的组成

按钮部分:
① LV_PART_MAIN:按钮的主体背景;
② LV_PART_INDICATOR:指示器,例如上图向下的箭头。
列表部分:
③ LV_PART_SELECTED:当前选中的选项;
④ LV_PART_SCROLLBAR:滚动条;
⑤ LV_PART_MAIN:列表主体背景。 注意: 用户需要设置上述组成部分的样式,需要先将按钮或列表相关的部分获取回来。

■ 添加选项

lv_dropdown_set_options(dropdown, "First \n Second \n Third");
lv_dropdown_add_option(dropdown, "New option", pos);  //其形参 pos 表示添加的位置, 注意: 0 表示列表最上面的位置,
lv_dropdown_set_options_static (dropdown, options); //添加的是静态选项,在这种情况下,用户不能再使用lv_dropdown_add_option
void lv_mainstart(void)
{/* 创建一个下拉列表 */lv_obj_t* lv_ddlist1 = lv_dropdown_create(lv_scr_act());/* 方法一 添加多个选项(动态) */lv_dropdown_set_options(lv_ddlist1,"a\nb\nc\nd"); lv_obj_set_pos(lv_ddlist1,100, 100);/* 默认显示的选项 */lv_dropdown_set_selected(lv_ddlist1, 0);lv_obj_t* lv_ddlist2 = lv_dropdown_create(lv_scr_act());/* 方法二 添加单个选项 */lv_dropdown_add_option(lv_ddlist2,"0", 0);lv_dropdown_add_option(lv_ddlist2, "1", 1);lv_dropdown_add_option(lv_ddlist2, "2", 2);lv_dropdown_add_option(lv_ddlist2, "3", 3);/* 默认显示的选项 */lv_dropdown_set_selected(lv_ddlist2, 1);lv_obj_set_pos(lv_ddlist2, 300, 100);

■ 获取当前选中的选项

当用户选中所需的选项之后,如果没有任何反馈,这将无法和其他板块进行交互,因此, 我们需要在触发的事件回调中获取当前选中的选项索引和文本,

lv_dropdown_get_selected(dropdown)/* 获取选中的选项索引*/
lv_dropdown_get_selected_str(dropdown, buf, buf_size)/* 获取选项字符串,保存到指定的 buf 中。

■ 设置列表展开方向

lv_dropdown_set_dir(dropdown, LV_DIR_LEFT/RIGHT/UP/BOTTOM) /* 设置展开方向 */
void lv_mainstart(void)
{/* 创建一个下拉列表 */lv_obj_t* lv_ddlist1 = lv_dropdown_create(lv_scr_act());/*添加下拉列表项 */lv_dropdown_set_options(lv_ddlist1,"a\nb\nc\nd"); lv_obj_set_pos(lv_ddlist1,100, 100);/* 默认显示的下拉列表项 */lv_dropdown_set_selected(lv_ddlist1, 0);lv_obj_t* lv_ddlist2 =lv_dropdown_create(lv_scr_act());lv_dropdown_set_dir(lv_ddlist2,LV_DIR_LEFT); /* 设置为左侧展开 *//*添加下拉列表项 */lv_dropdown_add_option(lv_ddlist2, "0", 0);lv_dropdown_add_option(lv_ddlist2, "1", 1);lv_dropdown_add_option(lv_ddlist2, "2", 2);lv_dropdown_add_option(lv_ddlist2, "3", 3);/* 默认显示的下拉列表项 */lv_dropdown_set_selected(lv_ddlist2, 1);lv_obj_set_pos(lv_ddlist2, 300, 100);

在这里插入图片描述

■ 设置下拉列表图标

lv_dropdown_set_symbol(dropdown, LV_SYMBOL_…) /* 设置图标 */

在这里插入图片描述

■ 设置列表常显文本

lv_dropdown_set_text 函数,
在默认情况下,当用户选中某个选项后,该选项的文本会更新到列表的头部,示意图如下:
在这里插入图片描述

lv_mainstart(void)
{/* 创建一个下拉列表 */lv_obj_t* lv_ddlist1 =lv_dropdown_create(lv_scr_act());lv_dropdown_set_text(lv_ddlist1, "dropdown");/*添加下拉列表项 */lv_dropdown_set_options(lv_ddlist1,"a\nb\nc\nd"); lv_obj_set_pos(lv_ddlist1,100, 100);/* 默认显示哪一个下拉列表项 */lv_dropdown_set_selected(lv_ddlist1, 0);lv_obj_t* lv_ddlist2 =lv_dropdown_create(lv_scr_act());lv_dropdown_set_dir(lv_ddlist2,LV_DIR_LEFT);  /* 设置下拉方向 *//*添加下拉列表项 */lv_dropdown_add_option(lv_ddlist2, "0", 0);lv_dropdown_add_option(lv_ddlist2, "1", 1);lv_dropdown_add_option(lv_ddlist2, "2", 2);lv_dropdown_add_option(lv_ddlist2, "3", 3);/* 默认显示哪一个下拉列表项 */lv_dropdown_set_selected(lv_ddlist
}

在上述源码中,我们调用了 lv_dropdown_set_tex函数,把第一个列表( lv_ddlist1)的头部文本固定为“ dropdown”
在这里插入图片描述

■ 打开、开闭下拉列表

当用户需要直接打开或者关闭下拉列表时,可以直接调用以下函数

lv_dropdown_open(dropdown) /* 打开下拉列表 */
lv_dropdown_close(dropdown) /* 关闭下拉列表 */

■ 下拉列表部件的 API 函数

lv_dropdown_create() 创建下拉列表
lv_dropdown_set_text() 设置下拉列表按钮的文本(常显文本)
lv_dropdown_set_options() 添加选项(动态)
lv_dropdown_set_options_static() 添加选项(静态)
lv_dropdown_add_option() 添加单个选项
lv_dropdown_clear_options() 清除所有选项
lv_dropdown_set_selected() 设置当前所选项
lv_dropdown_set_dir() 设置展开方向
lv_dropdown_set_symbol() 设置图标
lv_dropdown_set_selected_highlight()设置当前选中的选项是否高亮
lv_dropdown_get_list() 获取下拉列表,以设置样式或进行其他修改
lv_dropdown_get_text() 获取下拉列表按钮的文本
lv_dropdown_get_options() 获取下拉列表的选项
lv_dropdown_get_selected() 获取所选选项的索引
lv_dropdown_get_option_cnt() 获取选项的总数
lv_dropdown_get_selected_str() 获取当前选中的选项文本
lv_dropdown_get_symbol() 获取图标
lv_dropdown_get_selected_highlight()判断当前选中的选项是否高亮
lv_dropdown_get_dir() 获取展开方向
lv_dropdown_open() 打开下拉列表
lv_dropdown_close() 关闭下拉列表

这篇关于【LVGL-下拉列表部件 lv_dropdown】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中数组转换为列表的两种实现方式(超简单)

《Java中数组转换为列表的两种实现方式(超简单)》本文介绍了在Java中将数组转换为列表的两种常见方法使用Arrays.asList和Java8的StreamAPI,Arrays.asList方法简... 目录1. 使用Java Collections框架(Arrays.asList)1.1 示例代码1.

python中列表list切分的实现

《python中列表list切分的实现》列表是Python中最常用的数据结构之一,经常需要对列表进行切分操作,本文主要介绍了python中列表list切分的实现,文中通过示例代码介绍的非常详细,对大家... 目录一、列表切片的基本用法1.1 基本切片操作1.2 切片的负索引1.3 切片的省略二、列表切分的高

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表

c++的初始化列表与const成员

初始化列表与const成员 const成员 使用const修饰的类、结构、联合的成员变量,在类对象创建完成前一定要初始化。 不能在构造函数中初始化const成员,因为执行构造函数时,类对象已经创建完成,只有类对象创建完成才能调用成员函数,构造函数虽然特殊但也是成员函数。 在定义const成员时进行初始化,该语法只有在C11语法标准下才支持。 初始化列表 在构造函数小括号后面,主要用于给

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent