用GUI做一个下拉列表吧,LVGL『Drop-down list下拉列表控件』介绍

原创 专注于无线通信的蓬勃 2021-02-27 08:22

一. LVGL GUI下拉列表控件的概念

下拉列表允许用户从列表中选择一个值。下拉列表默认情况下处于关闭状态,并显示单个值或预定义的文本。激活后(通过单击下拉列表),将创建一个列表,用户可以从中选择一个选项。当用户选择新值时,该列表将被删除。

二. LVGL GUI下拉列表小部件和样式

调用下拉列表的主要部分, LV_DROPDOWN_PART_MAIN 它是一个简单的 lv_obj 对象。它使用所有典型的背景属性。按下,聚焦,编辑等阶梯也照常应用。
单击主对象时创建的列表是 Page。它的背景部分可以被引用, LV_DROPDOWN_PART_LIST 并为矩形本身使用所有典型的背景属性,并为选项使用文本属性。要调整选项之间的间距,请使用
text_line_space 样式属性。填充值可用于在边缘上留出一些空间。页面的可滚动部分被隐藏,其样式始终为空(透明,无填充)。
滚动条可以被引用 LV_DROPDOWN_PART_SCRLBAR 并使用所有典型的背景属性。
可以 LV_DROPDOWN_PART_SELECTED 使用所有典型的背景属性引用并使用所选的选项。它将以其默认
状态在所选选项上绘制一个矩形,并在按下状态下在被按下的选项上绘制一个矩形

三. LVGL GUI下拉列表控件的使用

1. 设置选项(Set options)

有集中方法来设置下拉列表中的选项:

  • lv_dropdown_set_options(dropdown, options)
  • lv_dropdown_add_option(dropdown, "New option", pos)

用这个函数lv_dropdown_set_selected来设置默认的选择的选项

我们写一个程序创建3个下拉列表,第一个用lv_dropdown_set_options这种方法,第二个用这个方法lv_dropdown_add_option,第三个默认不添加,自己看效果体验下

void lvgl_dlist_set_option_test(void)
{
    lv_obj_t* ddlist1 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_dropdown_set_options(ddlist1, "0\n1\n2\n3");
    lv_obj_set_pos(ddlist1,100,100);
    lv_dropdown_set_selected(ddlist1,0);

    lv_obj_t* ddlist2 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_dropdown_add_option(ddlist2,"0",0);
    lv_dropdown_add_option(ddlist2, "1", 1);
    lv_dropdown_add_option(ddlist2, "2", 2);
    lv_dropdown_add_option(ddlist2, "3", 3);
    lv_dropdown_set_selected(ddlist2, 1);
    lv_obj_set_pos(ddlist2, 300, 100);

    lv_obj_t* ddlist3 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_obj_set_pos(ddlist3, 500, 100);
}

我们来实验下效果:

2. 获取选择的选项(Get selected option)

用这个函数lv_dropdown_get_selected_str(dropdown, buf, buf_size)来获取选择的选项,一般跟event配合来使用,在event的时候我们再来写代码

3. 方向(Direction)

下拉列表的方向,用这个函数设置lv_dropdown_set_dir(dropdown, LV_DROPDOWN_DIR_LEFT/RIGHT/UP/DOWN)

我们来体验下:

void lvgl_dlist_direct_test(void)
{
    lv_obj_t* ddlist1 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_obj_set_pos(ddlist1, 100, 300);
    lv_dropdown_set_dir(ddlist1, LV_DROPDOWN_DIR_DOWN);

    lv_obj_t* ddlist2 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_obj_set_pos(ddlist2, 300, 300);
    lv_dropdown_set_dir(ddlist2, LV_DROPDOWN_DIR_UP);

    lv_obj_t* ddlist3 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_obj_set_pos(ddlist3, 500, 300);
    lv_dropdown_set_dir(ddlist3, LV_DROPDOWN_DIR_LEFT);

    lv_obj_t* ddlist4 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_obj_set_pos(ddlist4, 700, 300);
    lv_dropdown_set_dir(ddlist4, LV_DROPDOWN_DIR_RIGHT);
}

4. 符号(Symbol)

设置下拉列表的符号,如图红框位置就是设置的符号,用这个函数设置lv_dropdown_set_symbol(ddlist3, LV_SYMBOL_LEFT);

对应的代码如下:

void lvgl_dlist_symbol_test(void)
{
    lv_obj_t* ddlist1 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_dropdown_set_options(ddlist1, "0\n1\n2\n3");
    lv_obj_set_pos(ddlist1, 100, 300);
    lv_dropdown_set_dir(ddlist1, LV_DROPDOWN_DIR_DOWN);
    lv_dropdown_set_symbol(ddlist1, LV_SYMBOL_DOWN);

    lv_obj_t* ddlist2 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_dropdown_set_options(ddlist2, "0\n1\n2\n3");
    lv_obj_set_pos(ddlist2, 300, 300);
    lv_dropdown_set_dir(ddlist2, LV_DROPDOWN_DIR_UP);
    lv_dropdown_set_symbol(ddlist2, LV_SYMBOL_UP);

    lv_obj_t* ddlist3 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_dropdown_set_options(ddlist3, "0\n1\n2\n3");
    lv_obj_set_pos(ddlist3, 500, 300);
    lv_dropdown_set_dir(ddlist3, LV_DROPDOWN_DIR_LEFT);
    lv_dropdown_set_symbol(ddlist3, LV_SYMBOL_LEFT);

    lv_obj_t* ddlist4 = lv_dropdown_create(lv_scr_act(), NULL);
    lv_dropdown_set_options(ddlist4, "0\n1\n2\n3");
    lv_obj_set_pos(ddlist4, 700, 300);
    lv_dropdown_set_dir(ddlist4, LV_DROPDOWN_DIR_RIGHT);
    lv_dropdown_set_symbol(ddlist4, LV_SYMBOL_RIGHT);
}

5. 最大高度(Maximum height)

通过这个函数来设置lv_dropdown_set_max_height(dropdown, height)

6. 显示选择(Show selected)

主要部分可以显示所选选项或静态文本。可以用这个函数lv_dropdown_set_show_selected(sropdown, true/false)设置

7. 动画时间(Animation time)

其实在最新版本中,我并没有找到这个函数

8. 手动开启/关闭(Manually open/close)

用这个函数lv_dropdown_open/close(dropdown, LV_ANIM_ON/OFF)打开跟关闭

9. 事件(Event)

除了基本的事件外,我们来看下这个当选择值改变的时候产生的事件

LV_EVENT_VALUE_CHANGED - Sent when the new option is selected.

我们来看下程序

static void droup_list_event_handler(lv_obj_t* obj, lv_event_t event)
{
    if (event == LV_EVENT_VALUE_CHANGED) {
        char buf[32];
        lv_dropdown_get_selected_str(obj, buf, sizeof(buf));
        printf("Option: %s\n", buf);
    }
}

void lvgl_drop_list_test1(void)
{

    /*Create a normal drop down list*/
    lv_obj_t* ddlist = lv_dropdown_create(lv_scr_act(), NULL);
    lv_dropdown_set_options(ddlist, "Apple\n"
        "Banana\n"
        "Orange\n"
        "Melon\n"
        "Grape\n"
        "Raspberry");

    lv_obj_align(ddlist, NULL, LV_ALIGN_IN_TOP_MID, 0, 20);
    lv_obj_set_event_cb(ddlist, droup_list_event_handler);
}

看下效果图

好了,完结了,更多精彩继续戳↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

专注于无线通信的蓬勃 朝气蓬勃——不积跬步 无以至千里, 不积小流 无以成江海
评论
  • 近年来,云终端凭借便捷、高效、高性价比的优势正逐步在各行各业渗透。研究机构IDC的数据显示,2024上半年,中国云终端市场总体出货量达到166.3万台,同比增长22.4%,销售额29亿元人民币,同比增长24.9%,均超预期。紫光展锐积极携手各大合作伙伴,共同打造云端生态,大力推动云终端在政企、金融类等领域应用落地。 云终端增长势头良好 两大应用场景被看好云电脑将传统个人电脑的硬件资源和软件应用虚拟化,并通过网络提供给用户。这种模式的核心在于:用户不需要高性能的本地硬件,仅通过互联网连接
    紫光展锐 2024-12-16 18:11 45浏览
  • 全球领先的光学解决方案供应商艾迈斯欧司朗(瑞士证券交易所股票代码:AMS)于10月23日在深圳益田威斯汀酒店举办了艾迈斯欧司朗中国发展中心(以下简称,CDC)圆桌论坛。本次论坛以“智能化时代,以多元应用场景和技术 助力中国市场加速发展”为核心议题,探讨在人工智能驱动的市场趋势下,CDC如何助力中国伙伴把握时代机遇,推动大中华地区业务稳健增长,展示了艾迈斯欧司朗对中国市场的信心。立足中国 贴近本土客户需求在全球经济增速放缓和国际形势复杂多变的背景下,中国市场依然保持了稳定的增长势态,并释放出强大的
    艾迈斯欧司朗 2024-12-16 18:00 111浏览
  • 在现代生活中,我们经常会遇到需要检测电线是否带电的情况。这时,一款好用的数显测电笔就显得尤为重要了。今天,我想跟大家分享一下DELIXI数显测电笔的使用方法,通过一个故事来讲述它如何帮助我们解决生活中的小麻烦。 在一个阳光明媚的周末,小明决定对他家的电路进行一次全面的检查。他知道,虽然自己不是专业的电工,但有了DELIXI数显测电笔的帮助,他也能轻松应对。 小明拿出了DELIXI数显测电笔,这款测电笔设计得非常人性化,操作起来也很简单。他首先注意到了测电笔上的两个按键:DIRECT(A键)和
    丙丁先生 2024-12-16 12:58 70浏览
  • 【富芮坤FR3068x-C】+开发环境疑问非常荣欣参加了这次《富芮坤FR3068x-C》评测活动,在搭建开发环境时,本人就遇到很大问题,主要有3个。第1个问题:本人按照《FR306x开发环境说明书》中的1章安装软件,keil5.36版本以上,并且打开sdk中uart工程,按照要求设置了Device配置如下: ARM Compiler选项链接文件配置但是编译结果如下:有23个warning,都是连接脚本中找不到,请问这样工程是否有问题?第2个问题:按照《FR306x开发环境说明书》中要求,需要电脑
    shenwen2007_656583087 2024-12-17 00:59 39浏览
  • 一、引言在数字化时代,芯片作为现代科技的核心,其制造过程却常被视作神秘的黑箱。菊地正典的《大话芯片制造》为我们揭开了这层神秘的面纱,以通俗易懂的方式,全面系统地介绍了芯片制造的各个环节。作为一名电子信息技术专业的教育工作者,我深感这本书不仅为学生提供了宝贵的知识资源,也让我对芯片制造及其在现代社会中的作用有了更深刻的理解。二、生活中的芯片印记芯片的影响渗透到我们日常生活的每一个角落。从智能手机的闹钟唤醒,到交通卡的便捷支付,再到智能家居的智能化功能,芯片以其强大的运算和处理能力,为我们的现代生活
    月光 2024-12-16 11:52 74浏览
  • 习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-14 20:56 70浏览
  • 串口调试助手软件:XCOM 也是一款专为嵌入式开发和硬件调试设计的强大工具,如正点原子串口调试助手 XCOM V2.6。这款软件支持多种串口参数配置,满足不同开发需求,广泛应用于嵌入式系统开发、硬件调试以及电子爱好者的项目开发中。XCOM在嵌入式开发和硬件调试中的作用主要体现在以下几个方面: 1. 串口通信测试:XCOM作为一款强大的串口调试工具,允许用户通过计算机的串口进行数据的发送与接收,从而实现对串口通信的测试。这对于验证硬件设备的通信协议、确保数据传输的正确性至关重要。 2. 数据发
    丙丁先生 2024-12-15 11:56 79浏览
  • 在现代软件开发领域,效率和可靠性是企业在竞争中取胜的关键。本文将深入探讨 ANA Systems 如何通过引入业界领先的 CI/CD 平台——CircleCI,克服传统开发流程的瓶颈,实现开发运营效率的全面提升。同时,本文还将详细解析 CircleCI 的核心优势,包括其强大的自动化功能、广泛的工具整合能力,以及为企业量身定制的支持服务,揭示其如何助力 ANA Systems 在「新一代国内旅客项目」中脱颖而出。这一案例将为企业优化开发流程、提升竞争力提供重要的实践参考。ANA Systems
    艾体宝IT 2024-12-16 16:44 94浏览
  • 1. 磁性材料的磁化曲线磁性材料是由铁磁性物质或亚铁磁性物质组成的,在外加磁场H 作用下,必有相应的磁化强度M 或磁感应强度B,它们随磁场强度H 的变化曲线称为磁化曲线(M~H或B~H曲线)。磁化曲线一般来说是非线性的,具有2个特点:磁饱和现象及磁滞现象。即当磁场强度H足够大时,磁化强度M达到一个确定的饱和值Ms,继续增大H,Ms保持不变;以及当材料的M值达到饱和后,外磁场H降低为零时,M并不恢复为零,而是沿MsMr曲线变化。材料的工作状态相当于M~H曲线
    锦正茂科技 2024-12-17 10:40 39浏览
  • 擎天柱,这个名字听起来就像是从科幻电影里走出来的英雄。但今天,我们要聊的不是那个变形金刚,而是一款同样令人兴奋的实验板——Ai8051U-LQFP48 转 89C52-DIP40 核心功能实验板。这款实验板就像是电子世界的“擎天柱”,它拥有强大的力量和无限的潜力,等待着我们去发掘和探索。 想象一下,你手中握着的不是一块普通的电路板,而是一张通往未来科技世界的门票。Ai8051U芯片,这颗强大的心脏,内置了硬件浮点运算单元(TFPU@120MHz),让你的计算速度飞起来,就像给机器人装上了翅膀。
    丙丁先生 2024-12-16 13:02 97浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦