• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# 延迟任务回调能力开发指导(WorkSchedulerExtensionAbility)
2
3对于实时性要求不高的任务或持久性任务,可以使用延迟任务,该机制会在应用满足应用设定条件(包括网络类型、充电类型、存储状态、电池状态、定时状态)时,根据系统当前状态,由系统统一决策调度时间。
4
5WorkSchedulerExtensionAbility提供了延迟任务回调能力,在延迟任务开始和结束时,系统会调用回调接口来处理任务逻辑,开发者可在回调接口里面编写自己的任务逻辑。
6
7## 运作机制
8
9延迟任务调度运作机制如图1所示。
10
11  **图1** 延迟任务调度运作机制 
12
13![WorkSchedulerExtensionAbility](figures/WorkSchedulerExtensionAbility.png)
14
15应用通过[延迟任务API](../reference/apis/js-apis-resourceschedule-workScheduler.md)注册、删除、查询任务,通过[延迟任务回调API](../reference/apis/js-apis-WorkSchedulerExtensionAbility.md)实现任务开始、结束的执行逻辑。
16应用服务侧进行条件检测和判断,若满足条件,则回调WorkSchedulerExtensionAbility拉起应用,执行onWorkStart、onWorkStop回调接口。
17
18## 接口说明
19
20WorkSchedulerExtensionAbility类拥有如下API接口,具体的API介绍详见[接口文档](../reference/apis/js-apis-WorkSchedulerExtensionAbility.md)。
21
22| 接口名 | 描述 |
23| -------- | -------- |
24| onWorkStart(work: workScheduler.WorkInfo): void | 延迟任务调度开始回调。 |
25| onWorkStop(work: workScheduler.WorkInfo): void | 延迟任务调度结束回调。 |
26
27## 开发步骤
28
29在DevEco Studio工程中新建一个WorkScheduler工程,主要涉及如下关键步骤:
30
31- [实现延迟任务回调拓展能力](#实现延迟任务回调拓展能力):开发延迟任务生命周期回调接口WorkSchedulerExtensionAbility。
32
33- [实现延迟任务调度能力](#实现延迟任务调度能力):开发延迟任务API,实现延迟任务注册、停止等功能。
34
35- [配置文件](#配置文件):配置应用配置文件module.json536
37### 实现延迟任务回调拓展能力
38
391. 在工程根目录新建Module,模板选择为Ohos Library,命名为library。
40
412. 在library对应的ets目录(./library/src/main/ets)下,新建ArkTS文件并命名为workAbility.ets,用于实现延迟任务回调接口。
42
43    导入模块。
44
45    ```ts
46    import WorkSchedulerExtensionAbility from '@ohos.WorkSchedulerExtensionAbility';
47    ```
48
49    实现WorkSchedulerExtension生命周期接口。
50
51    ```ts
52    export default class workAbility extends WorkSchedulerExtensionAbility {
53      // 延迟任务开始回调
54      onWorkStart(workInfo) {
55        console.log(`onWorkStart CommonEvent publish start ${JSON.stringify(workInfo)}`);
56        // 发送升级通知
57        let notificationRequest = notification.getNotificationContentBasic('upgrade', upgradeMessage, '');
58        notification.publish(notificationRequest, (err) => {
59          if (err) {
60            console.log(`onWorkStart notification publish err ${JSON.stringify(err)}`);
61          }
62          console.log(`onWorkStart notification publish success`);
63        });
64      }
65
66      // 延迟任务结束回调
67      onWorkStop(workInfo) {
68        // 发送升级完成通知
69        let notificationRequest = notification.getNotificationContentBasic('upgrade', 'upgrade success', '');
70        notification.publish(notificationRequest, (err) => {
71          if (err) {
72            console.log(`onWorkStop notification publish err ${JSON.stringify(err)}`);
73          }
74          console.log(`onWorkStop notification publish success`);
75        });
76      }
77    }
78    ```
79
803. 在工程entry Module对应的ets目录(./entry/src/main/ets)下,新建一个目录并命名为workAbility。
81   在workAbility目录下,新建一个ArkTS文件并命名为WorkTest.ets,实现延迟任务回调接口。
82
83    导入模块。
84
85    ```ts
86    import { workAbility } from '@ohos/library';
87    ```
88
89    继承workAbility,实现WorkSchedulerExtension生命周期接口。
90
91    ```ts
92    export default class WorkTest extends workAbility {
93      onWorkStart(workInfo) {
94        console.log(`onWorkStartTest start ${JSON.stringify(workInfo)}`);
95        super.onWorkStart(workInfo);
96      }
97
98      onWorkStopTest(workInfo) {
99        super.onWorkStop(workInfo);
100        console.log(`onWorkStop value`);
101      }
102    }
103    ```
104
105### 实现延迟任务调度能力
106
1071. 在library对应的ets目录(./library/src/main/ets)下,新建TypeScript文件并命名为DelayWork.ts,用于实现延迟任务API。
108
109    导入模块。
110
111    ```ts
112    import workScheduler from '@ohos.resourceschedule.workScheduler';
113    ```
114
115    封装延迟任务注册、停止接口。
116
117    ```ts
118    export default class DelayWork {
119      private workInfo = {
120        workId: 1,
121        networkType: workScheduler.NetworkType.NETWORK_TYPE_WIFI,
122        bundleName: '',
123        abilityName: ''
124      }
125      // 注册延迟任务
126      startWork(bundleName: string, abilityName: string) {
127        this.workInfo.bundleName = bundleName;
128        this.workInfo.abilityName = abilityName;
129        try {
130          workScheduler.startWork(this.workInfo);
131          console.log(`startWork success`);
132        } catch (error) {
133          Logger.error(TAG, `startWork startwork failed. code is ${error.code} message is ${error.message}`);
134          prompt.showToast({
135            message: `${error.message}`
136          })
137        }
138      }
139
140      // 停止延迟任务
141      stopWork(bundleName: string, abilityName: string) {
142        this.workInfo.bundleName = bundleName;
143        this.workInfo.abilityName = abilityName;
144        workScheduler.stopWork(this.workInfo, false);
145        console.log(`stopWork`);
146      }
147    }
148    ```
149
1502. 在工程entry Module对应的index页面(./entry/src/main/ets/pages/index.ets)下,增加“升级”按钮,调用library封装的延迟任务注册接口。
151
152    导入模块。
153
154    ```ts
155    import { workAbility } from '@ohos/library';
156    ```
157
158    增加“升级”按钮,调用library封装的延迟任务注册接口,传入bundleName和abilityName,其中bilityName为WorkTest。
159
160    ```ts
161    Button($r('app.string.upgrade'))
162      .width('60%')
163      .height(40)
164      .fontSize(30)
165      .onClick(() => {
166        this.work.startWork('ohos.samples.workscheduler', 'WorkTest');
167      })
168    ```
169
170    当组件析构时,调用延迟任务停止接口。
171
172    ```ts
173    aboutToDisappear() {
174      this.work.stopWork('ohos.samples.workscheduler', 'WorkTest');
175    }
176    ```
177
178### 配置文件
179
1801. 在工程entry Module对应的[module.json5配置文件](../quick-start/module-configuration-file.md)中注册WorkSchedulerExtensionAbility,type标签需要设置为“workScheduler”,srcEnty标签表示当前ExtensionAbility组件所对应的代码路径。
181
182  ```json
183  {
184    "module": {
185        "extensionAbilities": [
186          {
187            "name": "WorkTest",
188            "srcEnty": "./ets/workAbility/WorkTest.ets",
189            "label": "$string:WorkSchedulerExtensionAbility_label",
190            "description": "$string:WorkSchedulerExtensionAbility_desc",
191            "type": "workScheduler"
192          }
193        ]
194    }
195  }
196  ```
197
198## 相关实例
199
200针对WorkSchedulerExtensionAbility开发,有以下相关实例可供参考:
201
202- [WorkScheduler的创建与使用(ArkTS)(API9)](https://gitee.com/openharmony/applications_app_samples/tree/OpenHarmony-3.2-Release/code/BasicFeature/TaskManagement/WorkScheduler)
203
204