Keyboard(键盘)(lv_keyboard)¶
Overview(概述)¶
查看原文
The Keyboard object is a special Button matrix with predefined keymaps and other features to realize a virtual keyboard to write texts into a Text area.
键盘(lv_keyboard)对象是一个特殊的 按钮矩阵(lv_btnmatrix),自身实现了按键(map)映射和其他功能,目的是用于实现一个虚拟键盘将文本写入文本框(lv_textarea)。
Parts and Styles(部分和样式)¶
查看原文
Similarly to Button matrices Keyboards consist of 2 part:
LV_PART_MAIN
The main part. Uses all the typical background propertiesLV_PART_ITEMS
The buttons. Also uses all typical background properties as well as the text properties.
与按钮矩阵类似,键盘由 2 部分组成:
LV_PART_MAIN
主要部分(自身背景部分),使用所有组件默认都有的典型的背景样式属性。LV_PART_ITEMS
键盘中的按钮。使用所有典型的背景属性以及 text 属性。
Usage(用法)¶
Modes(模式)¶
查看原文
The Keyboards have the following modes:
LV_KEYBOARD_MODE_TEXT_LOWER
Display lower case lettersLV_KEYBOARD_MODE_TEXT_UPPER
Display upper case lettersLV_KEYBOARD_MODE_TEXT_SPECIAL
Display special charactersLV_KEYBOARD_MODE_NUMBER
Display numbers, +/- sign, and decimal dotLV_KEYBOARD_MODE_USER_1
throughLV_KEYBOARD_MODE_USER_4
User-defined modes.
The TEXT
modes' layout contains buttons to change mode.
To set the mode manually, use lv_keyboard_set_mode(kb, mode)
. The default mode is LV_KEYBOARD_MODE_TEXT_UPPER
.
键盘可以切换下面这几种输入模式:
LV_KEYBOARD_MODE_TEXT_LOWER
26键英文小写键盘模式LV_KEYBOARD_MODE_TEXT_UPPER
26键英文大写键盘模式LV_KEYBOARD_MODE_TEXT_SPECIAL
特殊字符输入模式LV_KEYBOARD_MODE_NUMBER
数字键盘模式。可以输入数字、+/- 符号和小数点LV_KEYBOARD_MODE_USER_1
到LV_KEYBOARD_MODE_USER_4
用户可自定义拓展的模式lvgl
更改模式会更改键盘的按钮的文字甚至布局。
您可以通过 lv_keyboard_set_mode(kb, mode)
函数手动设置模式。默认的模式是 LV_KEYBOARD_MODE_TEXT_UPPER
。
Assign Text area(指定文本框)¶
查看原文
You can assign a Text area to the Keyboard to automatically put the clicked characters there.
To assign the text area, use lv_keyboard_set_textarea(kb, ta)
.
你可以将文本框分配给键盘绑定,之后点击键盘上的按钮就能更改文本框中的内容。可以通过 lv_keyboard_set_textarea(kb, ta)
函数将文本框分配给键盘绑定。
Key Popovers(按键弹出提示)¶
查看原文
To enable key popovers on press, like on common Android and iOS keyboards, use lv_keyboard_set_popovers(kb, true)
. The default control maps are preconfigured to only show the popovers on keys that produce a symbol and not on e.g. space. If you use a custom keymap, set the LV_BTNMATRIX_CTRL_POPOVER
flag for all keys that you want to show a popover.
Note that popovers for keys in the top row will draw outside the widget boundaries. To account for this, reserve extra free space on top of the keyboard or ensure that the keyboard is added after any widgets adjacent to its top boundary so that the popovers can draw over those.
The popovers currently are merely a visual effect and don't allow selecting additional characters such as accents yet.
这个效果就像常见的安卓和iOS键盘上的效果:按下按键时会有在相应的按键之上弹出该按键提示当前按下的按钮。调用函数 lv_keyboard_set_popovers(kb, true)
即可得到这样得效果。默认控制map默认的配置是只在有text的按键上显示弹出提示框,而不会在空格键(space)上显示。如果使用自定义的按键map,请为所有要显示弹出框的按键设置 LV_BTNMATRIX_CTRL_POPOVER
标志。
请注意,顶行中的按键的弹出窗口将被绘制在超过键盘的边界之外。因此,建议在键盘顶部保留额外的可用空间,或确保在其顶部边界附近的任何其他组件(对象)之后再添加或者创建键盘,来确保弹出窗口不被这些组件遮挡。
目前,弹出窗口仅仅是一种视觉效果,还不支持使用其他字符,例如重音符号等。
New Keymap(自定义键盘布局)¶
查看原文
You can specify a new map (layout) for the keyboard with lv_keyboard_set_map(kb, map)
and lv_keyboard_set_ctrl_map(kb, ctrl_map)
.
Learn more about the Button matrix object.
Keep in mind that using following keywords will have the same effect as with the original map:
LV_SYMBOL_OK
Apply.LV_SYMBOL_CLOSE
orLV_SYMBOL_KEYBOARD
Close.LV_SYMBOL_BACKSPACE
Delete on the left.LV_SYMBOL_LEFT
Move the cursor left.LV_SYMBOL_RIGHT
Move the cursor right.LV_SYMBOL_NEW_LINE
New line."ABC" Load the uppercase map.
"abc" Load the lower case map.
"1#" Load the lower case map.
您可以使用 lv_keyboard_set_map(kb, map)
和 lv_keyboard_set_ctrl_map(kb, ctrl_map)
函数为键盘指定新的map(布局)。
了解有关 按钮矩阵 对象的更多信息。
请记住,使用以下关键字可以得到与内置map(布局)相同的效果:
LV_SYMBOL_OK
应用LV_SYMBOL_CLOSE
或者LV_SYMBOL_KEYBOARD
关闭。LV_SYMBOL_BACKSPACE
删除光标左侧的字符。LV_SYMBOL_LEFT
向左移动光标。LV_SYMBOL_RIGHT
向右移动光标。LV_SYMBOL_NEW_LINE
换行。"ABC" 切换为26键英文大写键盘布局。
"abc" 切换为26键英文大写键盘布局。
"1#" 切换为特殊字符键盘布局
Events(事件)¶
查看原文
LV_EVENT_VALUE_CHANGED
Sent when the button is pressed/released or repeated after long press. The event data is set to the ID of the pressed/released button.LV_EVENT_READY
- The Ok button is clicked.LV_EVENT_CANCEL
- The Close button is clicked.
The keyboard has a default event handler callback called lv_keyboard_def_event_cb
, which handles the button pressing, map changing, the assigned text area, etc. You can remove it and replace it with a custom event handler if you wish.
注解
In 8.0 and newer, adding an event handler to the keyboard does not remove the default event handler. This behavior differs from v7, where adding an event handler would always replace the previous one.
Learn more about Events.
LV_EVENT_VALUE_CHANGED
当按钮被按下/释放或允许长按后重复时发送。事件数据设置为按下/释放的按钮的 ID 。LV_EVENT_READY
- Ok (LV_SYMBOL_OK)按钮被点击LV_EVENT_CANCEL
- Close (LV_SYMBOL_CLOSE
)按钮被点击
键盘有一个默认的事件处理回调函数: lv_keyboard_def_event_cb
。其用于处理按钮的按下、map(布局)的更改、绑定的文本框等。如果您愿意,可以将其删除并替换为自定义的事件处理回调函数。
注解
在 8.0 及更高版本中,向键盘添加事件处理回调函数不会删除默认(之前)的事件处理回调函数。此行为与 v7 不同,因为在 v7 中,新的事件处理回调函数会替换之前的。
了解有关 事件 的更多信息。
Keys(按键)¶
查看原文
LV_KEY_RIGHT/UP/LEFT/RIGHT
To navigate among the buttons and select one.LV_KEY_ENTER
To press/release the selected button.
Learn more about Keys.
LV_KEY_RIGHT/UP/LEFT/RIGHT
通过导航模式选中按钮。LV_KEY_ENTER
按下/释放所选中按钮(模拟触摸点击的效果)。
了解关于 按键 的更多信息。
Examples(示例)¶
Keyboard with text area¶
C code
GitHub#include "../../lv_examples.h"
#if LV_USE_KEYBOARD && LV_BUILD_EXAMPLES
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_event_get_user_data(e);
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);
}
}
void lv_example_keyboard_1(void)
{
/*Create a keyboard to use it with an of the text areas*/
lv_obj_t *kb = lv_keyboard_create(lv_scr_act());
/*Create a text area. The keyboard will write here*/
lv_obj_t * ta;
ta = lv_textarea_create(lv_scr_act());
lv_obj_align(ta, LV_ALIGN_TOP_LEFT, 10, 10);
lv_obj_add_event_cb(ta, ta_event_cb, LV_EVENT_ALL, kb);
lv_textarea_set_placeholder_text(ta, "Hello");
lv_obj_set_size(ta, 140, 80);
ta = lv_textarea_create(lv_scr_act());
lv_obj_align(ta, LV_ALIGN_TOP_RIGHT, -10, 10);
lv_obj_add_event_cb(ta, ta_event_cb, LV_EVENT_ALL, kb);
lv_obj_set_size(ta, 140, 80);
lv_keyboard_set_textarea(kb, ta);
}
#endif
def ta_event_cb(e,kb):
code = e.get_code()
ta = e.get_target()
if code == lv.EVENT.FOCUSED:
kb.set_textarea(ta)
kb.clear_flag(lv.obj.FLAG.HIDDEN)
if code == lv.EVENT.DEFOCUSED:
kb.set_textarea(None)
kb.add_flag(lv.obj.FLAG.HIDDEN)
# Create a keyboard to use it with one of the text areas
kb = lv.keyboard(lv.scr_act())
# Create a text area. The keyboard will write here
ta = lv.textarea(lv.scr_act())
ta.set_width(200)
ta.align(lv.ALIGN.TOP_LEFT, 10, 10)
ta.add_event_cb(lambda e: ta_event_cb(e,kb), lv.EVENT.ALL, None)
ta.set_placeholder_text("Hello")
ta = lv.textarea(lv.scr_act())
ta.set_width(200)
ta.align(lv.ALIGN.TOP_RIGHT, -10, 10)
ta.add_event_cb(lambda e: ta_event_cb(e,kb), lv.EVENT.ALL, None)
kb.set_textarea(ta)
API¶
Typedefs
-
typedef uint8_t lv_keyboard_mode_t¶
Enums
-
enum [anonymous]¶
Current keyboard mode.
Values:
-
enumerator LV_KEYBOARD_MODE_TEXT_LOWER¶
-
enumerator LV_KEYBOARD_MODE_TEXT_UPPER¶
-
enumerator LV_KEYBOARD_MODE_SPECIAL¶
-
enumerator LV_KEYBOARD_MODE_NUMBER¶
-
enumerator LV_KEYBOARD_MODE_USER_1¶
-
enumerator LV_KEYBOARD_MODE_USER_2¶
-
enumerator LV_KEYBOARD_MODE_USER_3¶
-
enumerator LV_KEYBOARD_MODE_USER_4¶
-
enumerator LV_KEYBOARD_MODE_TEXT_LOWER¶
Functions
-
lv_obj_t *lv_keyboard_create(lv_obj_t *parent)¶
Create a Keyboard object
- 参数
parent -- pointer to an object, it will be the parent of the new keyboard
- 返回
pointer to the created keyboard
-
void lv_keyboard_set_textarea(lv_obj_t *kb, lv_obj_t *ta)¶
Assign a Text Area to the Keyboard. The pressed characters will be put there.
- 参数
kb -- pointer to a Keyboard object
ta -- pointer to a Text Area object to write there
-
void lv_keyboard_set_mode(lv_obj_t *kb, lv_keyboard_mode_t mode)¶
Set a new a mode (text or number map)
- 参数
kb -- pointer to a Keyboard object
mode -- the mode from 'lv_keyboard_mode_t'
-
void lv_keyboard_set_popovers(lv_obj_t *kb, bool en)¶
Show the button title in a popover when pressed.
- 参数
kb -- pointer to a Keyboard object
en -- whether "popovers" mode is enabled
-
void lv_keyboard_set_map(lv_obj_t *kb, lv_keyboard_mode_t mode, const char *map[], const lv_btnmatrix_ctrl_t ctrl_map[])¶
Set a new map for the keyboard
- 参数
kb -- pointer to a Keyboard object
mode -- keyboard map to alter 'lv_keyboard_mode_t'
map -- pointer to a string array to describe the map. See 'lv_btnmatrix_set_map()' for more info.
-
lv_obj_t *lv_keyboard_get_textarea(const lv_obj_t *kb)¶
Assign a Text Area to the Keyboard. The pressed characters will be put there.
- 参数
kb -- pointer to a Keyboard object
- 返回
pointer to the assigned Text Area object
-
lv_keyboard_mode_t lv_keyboard_get_mode(const lv_obj_t *kb)¶
Set a new a mode (text or number map)
- 参数
kb -- pointer to a Keyboard object
- 返回
the current mode from 'lv_keyboard_mode_t'
-
bool lv_btnmatrix_get_popovers(const lv_obj_t *obj)¶
Tell whether "popovers" mode is enabled or not.
- 参数
kb -- pointer to a Keyboard object
- 返回
true: "popovers" mode is enabled; false: disabled
-
static inline const char **lv_keyboard_get_map_array(const lv_obj_t *kb)¶
Get the current map of a keyboard
- 参数
kb -- pointer to a keyboard object
- 返回
the current map
-
static inline uint16_t lv_keyboard_get_selected_btn(const lv_obj_t *obj)¶
Get the index of the lastly "activated" button by the user (pressed, released, focused etc) Useful in the
event_cb
to get the text of the button, check if hidden etc.- 参数
obj -- pointer to button matrix object
- 返回
index of the last released button (LV_BTNMATRIX_BTN_NONE: if unset)
-
static inline const char *lv_keyboard_get_btn_text(const lv_obj_t *obj, uint16_t btn_id)¶
Get the button's text
- 参数
obj -- pointer to button matrix object
btn_id -- the index a button not counting new line characters.
- 返回
text of btn_index` button
-
void lv_keyboard_def_event_cb(lv_event_t *e)¶
Default keyboard event to add characters to the Text area and change the map. If a custom
event_cb
is added to the keyboard this function can be called from it to handle the button clicks- 参数
kb -- pointer to a keyboard
event -- the triggering event
Variables
-
const lv_obj_class_t lv_keyboard_class¶
-
struct lv_keyboard_t¶