未验证 提交 3240e3da 编写于 作者: O openharmony_ci 提交者: Gitee

!14889 【输入法框架】InputMethodExtentionAbility开发指南中增加签名指导说明

Merge pull request !14889 from Hollokin/master
...@@ -19,7 +19,7 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis ...@@ -19,7 +19,7 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis
> 如果服务已创建,再次启动该InputMethodExtensionAbility不会触发onCreate()回调。 > 如果服务已创建,再次启动该InputMethodExtensionAbility不会触发onCreate()回调。
- **onDestroy** - **onDestroy**
当不再使用服务且准备将其销毁该实例时,触发该回调。开发者可以在该回调中清理资源,如注销监听等。 当不再使用服务且准备将该实例销毁时,触发该回调。开发者可以在该回调中清理资源,如注销监听等。
## 开发步骤 ## 开发步骤
...@@ -28,19 +28,22 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis ...@@ -28,19 +28,22 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis
在工程Module对应的ets目录下,右键选择“New > Extention Ability > InputMethod”,即可创建出InputMethodExtensionAbility的最小化模板。 在工程Module对应的ets目录下,右键选择“New > Extention Ability > InputMethod”,即可创建出InputMethodExtensionAbility的最小化模板。
> **说明:**
> 在编译输入法应用时,要使用system_core级别的签名,否则无法拉起输入法键盘。
> [签名指导](https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ohos-auto-configuring-signature-information-0000001271659465)
最小化模板为一个最基本的输入法应用,包含软键盘拉起以及输入删除功能。后续开发者可在此基础上添加功能,如隐藏键盘等,实现自己的输入法应用。 最小化模板为一个最基本的输入法应用,包含软键盘拉起以及输入删除功能。后续开发者可在此基础上添加功能,如隐藏键盘等,实现自己的输入法应用。
最小化模板主要包含四个文件,分别为KeyboardController.ts、InputMethodService.ts、Index.ets以及KeyboardKeyData.ts。目录如下: 最小化模板主要包含四个文件,分别为KeyboardController.ts、InputMethodService.ts、Index.ets以及KeyboardKeyData.ts。目录如下:
``` ```
/src/main/ /src/main/
├── ets/InputMethodExtAbility ├── ets/inputmethodextability
│ └──model/KeyboardController.ts # 显示键盘 │ └──model/KeyboardController.ts # 显示键盘
│ └──InputMethodService.ts # 自定义类继承InputMethodExtensionAbility并加上需要的生命周期回调 │ └──InputMethodService.ts # 自定义类继承InputMethodExtensionAbility并加上需要的生命周期回调
│ └──pages │ └──pages
│ └──InputMethodExtAbility │ └── Index.ets # 绘制键盘,添加输入删除功能
│ └── Index.ets # 绘制键盘,添加输入删除功能 │ └── KeyboardKeyData.ts # 键盘属性定义
│ └── KeyboardKeyData.ts # 键盘属性定义
├── resources/base/profile/main_pages.json ├── resources/base/profile/main_pages.json
``` ```
...@@ -64,7 +67,7 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis ...@@ -64,7 +67,7 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis
onDestroy() { onDestroy() {
console.log("onDestroy."); console.log("onDestroy.");
this.context.destroy() this.context.destroy();
} }
} }
``` ```
...@@ -72,16 +75,16 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis ...@@ -72,16 +75,16 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis
2. KeyboardController.ts文件。 2. KeyboardController.ts文件。
```ts ```ts
import inputMethodEngine from '@ohos.inputMethodEngine' import inputMethodEngine from '@ohos.inputMethodEngine';
import display from '@ohos.display' import display from '@ohos.display';
import windowManager from '@ohos.window' import windowManager from '@ohos.window';
// 调用输入法框架的getInputMethodAbility方法获取实例,并由此实例调用输入法框架功能接口 // 调用输入法框架的getInputMethodAbility方法获取实例,并由此实例调用输入法框架功能接口
globalThis.inputAbility = inputMethodEngine.getInputMethodAbility(); globalThis.inputAbility = inputMethodEngine.getInputMethodAbility();
export class KeyboardController { export class KeyboardController {
mContext // 保存InputMethodExtensionAbility中的context属性 mContext; // 保存InputMethodExtensionAbility中的context属性
WINDOW_TYPE_INPUT_METHOD_FLOAT = 2105 // 定义窗口类型,2105代表输入法窗口类型,用于创建输入法应用窗口 WINDOW_TYPE_INPUT_METHOD_FLOAT = 2105; // 定义窗口类型,2105代表输入法窗口类型,用于创建输入法应用窗口
windowName = 'inputApp'; windowName = 'inputApp';
private windowHeight: number = 0; private windowHeight: number = 0;
private windowWidth: number = 0; private windowWidth: number = 0;
...@@ -101,32 +104,31 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis ...@@ -101,32 +104,31 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis
public onDestroy(): void // 应用生命周期销毁 public onDestroy(): void // 应用生命周期销毁
{ {
this.unRegisterListener(); // 注销事件监听 this.unRegisterListener(); // 注销事件监听
var win = windowManager.findWindow(this.windowName) let win = windowManager.findWindow(this.windowName);
win.destroyWindow() // 销毁窗口 win.destroyWindow(); // 销毁窗口
this.mContext.terminateSelf(); // 销毁InputMethodExtensionAbility服务 this.mContext.terminateSelf(); // 销毁InputMethodExtensionAbility服务
} }
private initWindow(): void // 初始化窗口 private initWindow(): void // 初始化窗口
{ {
display.getDefaultDisplay().then(dis => { let dis = display.getDefaultDisplaySync();
var dWidth = dis.width; let dWidth = dis.width;
var dHeight = dis.height; let dHeight = dis.height;
var keyHeightRate = 0.47; let keyHeightRate = 0.47;
var keyHeight = dHeight * keyHeightRate; let keyHeight = dHeight * keyHeightRate;
this.windowWidth = dWidth; this.windowWidth = dWidth;
this.windowHeight = keyHeight; this.windowHeight = keyHeight;
this.nonBarPosition = dHeight - keyHeight this.nonBarPosition = dHeight - keyHeight;
var config = { let config = {
name: this.windowName, name: this.windowName,
windowType: this.WINDOW_TYPE_INPUT_METHOD_FLOAT, windowType: this.WINDOW_TYPE_INPUT_METHOD_FLOAT,
ctx: this.mContext ctx: this.mContext
} }
windowManager.createWindow(config).then((win) => { // 根据窗口类型创建窗口 windowManager.createWindow(config).then((win) => { // 根据窗口类型创建窗口
win.resize(dWidth, keyHeight).then(() => { win.resize(dWidth, keyHeight).then(() => {
win.moveWindowTo(0, this.nonBarPosition).then(() => { win.moveWindowTo(0, this.nonBarPosition).then(() => {
win.setUIContent('pages/InputMethodExtAbility/Index').then(() => { win.setUIContent('pages/InputMethodExtAbility/Index').then(() => {
});
}); });
}); });
}); });
...@@ -153,7 +155,7 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis ...@@ -153,7 +155,7 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis
globalThis.keyboardController = kbController; globalThis.keyboardController = kbController;
}) })
globalThis.inputAbility.on('inputStop', (imeId) => { globalThis.inputAbility.on('inputStop', (imeId) => {
if (imeId == "com.example.kikainput/InputDemoService") { if (imeId == "包名/Ability名") {
this.onDestroy(); this.onDestroy();
} }
}); });
...@@ -162,12 +164,12 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis ...@@ -162,12 +164,12 @@ InputMethodExtensionAbility通过[InputMethodExtensionContext](../reference/apis
private unRegisterListener(): void private unRegisterListener(): void
{ {
globalThis.inputAbility.off('inputStart'); globalThis.inputAbility.off('inputStart');
globalThis.inputAbility.off('inputStop'); globalThis.inputAbility.off('inputStop', () => {});
globalThis.inputAbility.off('keyboardShow'); globalThis.inputAbility.off('keyboardShow');
} }
private showHighWindow() { private showHighWindow() {
var win = windowManager.findWindow(this.windowName) let win = windowManager.findWindow(this.windowName)
win.resize(this.windowWidth, this.windowHeight).then(() => { win.resize(this.windowWidth, this.windowHeight).then(() => {
win.moveWindowTo(0, this.nonBarPosition).then(() => { win.moveWindowTo(0, this.nonBarPosition).then(() => {
win.showWindow().then(() => { win.showWindow().then(() => {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册