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 ...
随机推荐
- 【Kaggle】如何有效避免OOM(out of memory)和漫长的炼丹过程
本文介绍一些避免transformers的OOM以及训练等流程太漫长的方法,主要参考了kaggle notebook Optimization approaches for Transformers ...
- ETL工具 Flume (一)
分布式日志采集系统Flume学习 一.Flume架构 1.1 Hadoop业务开发流程 1.2 Flume概述 flume是一个分布式.可靠.和高可用的海量日志采集.聚合和传输的系统. 支持在日志系统 ...
- 清北学堂 2020 国庆J2考前综合强化 Day7
目录 1. 题目 T1 魔力石 题目描述 Sol T2 和 题目描述 Sol T3 数对 题目描述 Sol T4 海豹王国 题目描述 Sol 考场策略 1. 题目 T1 魔力石 题目描述 题目描述 小 ...
- 适合初学者的使用CNN的数字图像识别项目:Digit Recognizer with CNN for beginner
准备工作 数据集介绍 数据文件 train.csv 和 test.csv 包含从零到九的手绘数字的灰度图像. 每张图像高 28 像素,宽 28 像素,总共 784 像素.每个像素都有一个与之关联的像素 ...
- 基于python3.7利用Motor来异步读写Mongodb提高效率
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_111 如果使用Python做大型海量数据批量任务时,并且backend用mongodb做数据储存时,常常面临大量读写数据库的情况. ...
- 6.20 NOI 模拟
\(T1\ left\ xor\ right\) 考虑把询问离线,查询变成 \([0,x-1]\) 的 \([l,r]\) 的区间和与 \([0,y]\) 的 \([l,r]\) 的区间和的差 考虑线 ...
- MGR的gtid_executed不连续的问题分析
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 1.问题描述 在做MGR测试的时候偶尔遇到gtid_executed事务ID不连续的问题,但是并不影响数据库的正常运行.现 ...
- 最新30系显卡搭建paddle飞浆环境|含CUDA下载安装
下载CUDA 通过这个链接可以下载任意CUDA版本:CUDA Toolkit Archive | NVIDIA Developer 我下载的是这一个:https://developer.downloa ...
- springmvc静态资源配置
<servlet> <servlet-name>dispatcher</servlet-name> <servlet-class>org.springf ...
- Unity3D学习笔记11——后处理
目录 1. 概述 2. 详论 2.1. 实现 2.2. 解析 1. 概述 一般来说,图形渲染引擎都会把帧缓冲(Framebuffer)技术封装成两个接口,其中之一就是后处理(Post-process) ...