输入法子类型开发指南
输入法子类型允许输入法展现不同的输入模式或语言,用户可以根据需要在不同模式和语言中切换。如输入法的中文键盘、英文键盘等,都属于输入法的子类型。
输入法子类型的配置与实现
-
输入法应用开发者只需要注册实现一个InputMethodExtensionAbility,所有的输入法子类型共用该InputMethodExtensionAbility,在module.json5配置文件中添加metadata,name为ohos.extension.input_method,用于配置所有子类型的资源信息。
"extensionAbilities": [{"srcEntry": "./ets/InputMethodExtensionAbility/InputMethodService.ets","name": "InputMethodService","label": "$string:MainAbility_label","description": "$string:extension_ability_descriptor","type": "inputMethod","exported": true,"metadata": [{"name": "ohos.extension.input_method","resource": "$profile:input_method_config"}]}], -
子类型配置文件input_method_config.json需要放在应用资源目录的profile文件夹中,格式如下,字段释义参照InputMethodSubtype;开发者需要严格按照配置文件格式及字段进行子类型信息配置,locale字段的配置参照i18n-locale-culture。
{"subtypes": [{"icon": "$media:icon","id": "InputMethodExtAbility","label": "$string:english","locale": "en-US","mode": "lower"},{"icon": "$media:icon","id": "InputMethodExtAbility1","label": "$string:chinese","locale": "zh-CN","mode": "lower"}]} -
输入法应用中监听子类型事件,根据不同的子类型,可以加载不同的软键盘界面,或者通过状态变量控制软键盘显示效果。
// 设置监听子类型事件,改变输入法应用界面inputMethodAbility.on('setSubtype', (inputMethodSubtype: InputMethodSubtype) => {if (inputMethodSubtype.id === 'InputMethodExtAbility') {AppStorage.setOrCreate('subtypeChange', 0);}if (inputMethodSubtype.id === 'InputMethodExtAbility1') {AppStorage.setOrCreate('subtypeChange', 1);}});
输入法子类型相关信息的获取
- 开发者可以通过调用getCurrentInputMethodSubtype获取当前输入法应用的当前子类型。
- 开发者可以通过调用listCurrentInputMethodSubtype获取当前输入法应用的所有子类型。
- 开发者可以通过调用listInputMethodSubtype获取指定输入法应用的所有子类型。
输入法子类型的切换
- 开发者可以通过调用switchCurrentInputMethodSubtype切换当前输入法应用的子类型。
- 开发者可以通过调用switchCurrentInputMethodAndSubtype切换至指定输入法应用的指定子类型。