LVGL 虚拟键盘使用
一、使用例程

二、使用方式
函数的详细说明请看 lv_keyboard.h 文件
创建对象
lv_obj_t * lv_keyboard_create(lv_obj_t * parent); lv_obj_t * kb = lv_keyboard_create(lv_scr_act());
设置模式
void lv_keyboard_set_mode(lv_obj_t * kb, lv_keyboard_mode_t mode);
- LV_KEYBOARD_MODE_TEXT_LOWER - 显示小写字母
- LV_KEYBOARD_MODE_TEXT_UPPER - 显示大写字母
- LV_KEYBOARD_MODE_TEXT_SPECIAL - 显示特殊字符
- LV_KEYBOARD_MODE_NUM - 显示数字,+ /-号和小数点。
注意:默认更多是 LV_KEYBOARD_MODE_TEXT_UPPER 。
分配文本区域
void lv_keyboard_set_textarea(lv_obj_t * kb, lv_obj_t * ta);
将文本输入区与键盘进行关联
自定义键盘
typedef uint16_t lv_btnmatrix_ctrl_t; void lv_keyboard_set_map(lv_obj_t * kb, lv_keyboard_mode_t mode, const char * map[],
const lv_btnmatrix_ctrl_t ctrl_map[]);
详细用法见lv_example_keyboard_2()
注意:以下关键字将具有与原始键盘相同的效果:- LV_SYMBOL_OK: 应用.
- LV_SYMBOL_CLOSE: 关闭.
- LV_SYMBOL_BACKSPACE: 从左侧删除。
- LV_SYMBOL_LEFT: 向左移动光标。
- LV_SYMBOL_RIGHT: 向右移动光标。
- “ABC”: 加载大写键盘。
- “abc”: 加载小写键盘。
- “Enter”: 换行.
事件
除了 通用事件 ,键盘还支持以下 特殊事件 :- LV_EVENT_VALUE_CHANGED:按下/释放按钮时发送,或长按后重复发送。事件数据设置为按下/释放按钮的ID。
- LV_EVENT_READY: OK按钮被点击
- LV_EVENT_CANCEL:关闭按钮被点击
三、程序
#include "lvgl/lvgl.h"
/**
* @brief 文本事件
* @param e 事件对象
*/
static void ta_event_cb(lv_event_t * e)
{
lv_event_code_t code = lv_event_get_code(e); // 获取事件编码
lv_obj_t * ta = lv_event_get_target(e); // 获取文本对象
lv_obj_t * kb = (lv_obj_t *)lv_event_get_user_data(e); // 获取键盘对象
/* 获取文本点击事件 */
if(code == LV_EVENT_CLICKED) {
lv_keyboard_set_textarea(kb, ta); // 将键盘与文本进行关联
lv_obj_clear_flag(kb, LV_OBJ_FLAG_HIDDEN); // 清除键盘的隐身标志,显示键盘
lv_obj_add_state(ta, LV_STATE_FOCUSED); // 将文本框设置为聚焦状态
}
/* 获取文本聚焦事件 */
// if(code == LV_EVENT_FOCUSED) {
// lv_keyboard_set_textarea(kb, ta); // 将键盘与文本进行关联
// lv_obj_clear_flag(kb, LV_OBJ_FLAG_HIDDEN); // 清除键盘的隐身标志,显示键盘
// }
/* 获取文本失去焦点事件 */
if(code == LV_EVENT_DEFOCUSED) {
lv_keyboard_set_textarea(kb, NULL); // 取消键盘的关联
lv_obj_add_flag(kb, LV_OBJ_FLAG_HIDDEN); // 添加键盘隐藏标志,隐藏键盘
}
}
/**
* @brief 键盘确认事件
* @param e 事件对象
*/
static void kb_event_cb(lv_event_t * e)
{
lv_obj_t * kb = lv_event_get_target(e); // 获取当前事件对象,也就是键盘对象
lv_obj_t * ta = lv_keyboard_get_textarea(kb); // 获取与键盘绑定的输入缓冲区的对象
lv_keyboard_set_textarea(kb, NULL); // 取消键盘的关联
lv_obj_add_flag(kb, LV_OBJ_FLAG_HIDDEN); // 添加键盘隐藏标志,隐藏键盘
lv_obj_clear_state(ta, LV_STATE_FOCUSED); // 清除文本框的聚焦状态
}
/**
* @brief 键盘输入测试案例
*/
void lv_example_keyboard(void)
{
/* 创建一个键盘对象 */
lv_obj_t * kb = lv_keyboard_create(lv_scr_act());
/* 创建一个文本区域,用于键盘输入后的信息 */
lv_obj_t * ta = lv_textarea_create(lv_scr_act());
lv_obj_align(ta, LV_ALIGN_TOP_MID, 0, 10); // 相对位置设置
lv_obj_set_size(ta, lv_pct(90), 80); // 文本框大小
lv_textarea_set_placeholder_text(ta, "Click Enter"); // 文本提示信息
lv_obj_add_state(ta, LV_STATE_DEFAULT); // 设置文本框为默认状态
/* 文本控件的所有事件*/
lv_obj_add_event_cb(ta, ta_event_cb, LV_EVENT_ALL, kb);
/* 初始时将键盘隐藏 */
lv_keyboard_set_textarea(kb, NULL); // 未将键盘与输入区绑定
lv_obj_add_flag(kb, LV_OBJ_FLAG_HIDDEN); // 将表示将键盘隐藏
/* 键盘的确认事件 */
lv_obj_add_event_cb(kb, kb_event_cb, LV_EVENT_READY , NULL);
}
注意:从程序中可以看出,文本的输入状态只用聚焦和散焦即可,因为我想在键盘中通过确认按钮对键盘进行隐藏,但是又无法使文本进入散焦状态,存在点击文本时光标不闪烁的问题,所以我采取了点击事件,将文本改为聚焦状态。
如果哪位大佬知道怎么使文本散焦的办法,可否告知一下。
参考文献
LVGL 键盘|极客笔记:<https://deepinout.com/lvgl-tutorials/lvgl-widgets/lvgl-lv_keyboard.html
LVGL 虚拟键盘使用的更多相关文章
- Android开发案例 - 自定义虚拟键盘
所有包含IM功能的App(如微信, 微博, QQ, 支付宝等)都提供了Emoji表情之类的虚拟键盘, 如下图: 本文只着重介绍如何实现输入法键盘和自定义虚拟键盘的流畅切换, 而不介绍如何实现虚 ...
- Xamarin的不归路-安卓模拟器启动慢&没有虚拟键盘
1.启动慢解决方案:参考这篇文章进行配置 http://www.360doc.com/content/13/1002/18/532901_318605525.shtml 2.模拟器没有虚拟键盘解决方案 ...
- [原创]cocos2d-x研习录-第三阶 特性之按键与虚拟键盘
Cocos2D-x引擎支持按键事件,它能检测设备的键盘输入并处理相应的事件.而基于不同操作系统的移动设备,可供用户操作的按键数量和功能都存在差异. Cocos2D-x使用CCKeypadDeleg ...
- 039. asp.netWeb用户控件之七实现具有虚拟键盘的功能的用户控件
用户控件ascx代码: <%@ Control Language="C#" AutoEventWireup="true" CodeFile="K ...
- 关于Android 打开新的Activity 虚拟键盘的弹出与不弹出
关于Android 打开新的Activity 虚拟键盘的弹出与不弹出 打开Activity 时 在相应的情况 弹出虚拟键盘 或者 隐藏虚拟键盘 会给用户非常好的用户体验 , 实现起来也比较简单 只需 ...
- JS虚拟键盘
由于是触摸屏,所以需要一款JS虚拟键盘.上网找了一个好用的VirtualKeyboard,作了修改. 修改该插件参考的博客文章:http://www.cnblogs.com/xinggong/arch ...
- 【小贴士】虚拟键盘与fixed带给移动端的痛!
前言 今天来公司的主要目的就是研究虚拟键盘与fixed的问题,期间因为同事问起闭包与事件委托(阻止冒泡)相关问题,便穿插了一篇别的: [小贴士]工作中的”闭包“与事件委托的”阻止冒泡“,有兴趣的朋友可 ...
- WPF 虚拟键盘
之前做了一款WPF虚拟键盘,调用Win32的API,可以模拟键盘事件. 现将代码分享如下: 按键布局如下: <Button Name="> <StackPanel Orie ...
- 重新想象 Windows 8 Store Apps (49) - 输入: 获取输入设备信息, 虚拟键盘, Tab 导航, Pointer, Tap, Drag, Drop
[源码下载] 重新想象 Windows 8 Store Apps (49) - 输入: 获取输入设备信息, 虚拟键盘, Tab 导航, Pointer, Tap, Drag, Drop 作者:weba ...
随机推荐
- Graph-Based Social Relation Reasoning
title: Graph-Based Social Relation Reasoning, 2020 task: we propose a simpler, faster, and more accu ...
- 写出个灵活的系统竟然可以如此简单!小白也能写出高级的Java业务!
一 最近正好公司里有个需求,一个短信业务接了多个第三方供应商,某些业务需要查询第三方供应商剩余的短信包数量去选择剩余量最多的渠道去批量发送.有些业务是指定了某个短信供应商,有些场景需要根据业务的值去动 ...
- Spring学习笔记(4)Spring 事件原理及其应用
在 JDK 中已经提供相应的自定义事件发布功能的基础类: java.util.EventObject类 :自定义事件类型 java.util.EventListener接口:事件的监听器 首先了解几个 ...
- 揭开周获 18k star 开源项目的神秘面纱「GitHub 热点速览 v.22.28」
本周 GitHub Trending 的项目重量十足,比如标题的一周获得 18k+ 的高性能 JS Runtime--bun,用性能来体现了它的"含金量".同样有重量的还有一行代码 ...
- 基于NoCode构建简历编辑器
基于NoCode构建简历编辑器 基于NoCode构建简历编辑器,要参加秋招了,因为各种模版用起来细节上并不是很满意,所以尝试做个简单的拖拽简历编辑器. 描述 Github | Resume DEMO ...
- Python词频分析
Python词频分析 一.前言 在日常工作或者生活中,有时候会遇到词频分析的场景.如果是要进行词频分析,那么首先需要对句子进行分词,将句子中的单词进行切割并按照词性进行归类. 在Python中有个第三 ...
- 洛谷 P5627 题解
题意 Link 求 \[\sum_{i=1}^{2^n}\log_2\left(\prod_{j=1}^i\operatorname{lowbit}(j)\right) \] \(n\le 2^{64 ...
- linux 判断变量是否相等方法
echo $? 输出上一个命令执行成功与否的情况 1表示失败 0 表示成功 test检测文件类型和比较值 有空格时等号才是判断,否则为赋值
- 使用Django2.0.4集成钉钉第三方扫码登录
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_124 钉钉作为阿里旗下的一款免费移动通讯软件,受众群体越来越多,这里我们使用Django来集成一下钉钉的三方账号登录,首先注册钉钉 ...
- 面试突击71:GET 和 POST 有什么区别?
GET 和 POST 是 HTTP 请求中最常用的两种请求方法,在日常开发的 RESTful 接口中,都能看到它们的身影.而它们之间的区别,也是一道常见且经典的面试题,所以我们本文就来详细的聊聊. H ...