未验证 提交 e4bb793f 编写于 作者: 朱天怡 提交者: Gitee

修改

Signed-off-by: N朱天怡 <zhutianyi2@huawei.com>
上级 a8cfeb2d
# WorkSchedulerExtensionAbility(延迟任务调度回调 # 延迟任务调度回调开发指导(WorkSchedulerExtensionAbility
## 延迟任务概述 对于实时性要求不高的任务或持久性任务,可以使用延迟调度任务,该机制会在应用满足应用设定条件(包括网络类型、充电类型、存储状态、电池状态、定时状态)时,根据系统当前状态,由系统统一决策调度时间。
对于实时性要求不高的任务或持久性任务,可以使用延迟调度任务,该机制在满足应用设定条件的时候,会根据系统当前状态,如内存、功耗、温度等统一决策调度时间。
WorkSchedulerExtensionAbility提供了延迟任务回调能力,在延迟任务开始和结束时,系统会通过接口回调应用,开发者可在回调接口里面处理自己的任务逻辑。 WorkSchedulerExtensionAbility提供了延迟任务回调能力,在延迟任务开始和结束时,系统会通过接口回调应用,开发者可在回调接口里面处理自己的任务逻辑。
...@@ -42,16 +40,16 @@ WorkSchedulerExtensionAbility类拥有如下API接口,具体的API介绍详见 ...@@ -42,16 +40,16 @@ WorkSchedulerExtensionAbility类拥有如下API接口,具体的API介绍详见
2. 在library对应的ets目录(./library/src/main/ets)下,新建eTS文件并命名为workAbility.ets,用于实现延迟任务回调接口。 2. 在library对应的ets目录(./library/src/main/ets)下,新建eTS文件并命名为workAbility.ets,用于实现延迟任务回调接口。
> 导入模块。 导入模块。
```ts ```ts
import WorkSchedulerExtensionAbility from '@ohos.WorkSchedulerExtensionAbility' import WorkSchedulerExtensionAbility from '@ohos.WorkSchedulerExtensionAbility'
``` ```
> 实现WorkSchedulerExtension生命周期接口。 实现WorkSchedulerExtension生命周期接口。
```ts ```ts
export default class workAbility extends WorkSchedulerExtensionAbility { export default class workAbility extends WorkSchedulerExtensionAbility {
// 延迟任务开始回调 // 延迟任务开始回调
onWorkStart(workInfo) { onWorkStart(workInfo) {
Logger.info(TAG, `onWorkStart CommonEvent publish start ${JSON.stringify(workInfo)}`) Logger.info(TAG, `onWorkStart CommonEvent publish start ${JSON.stringify(workInfo)}`)
...@@ -76,22 +74,22 @@ export default class workAbility extends WorkSchedulerExtensionAbility { ...@@ -76,22 +74,22 @@ export default class workAbility extends WorkSchedulerExtensionAbility {
Logger.info(TAG, `onWorkStop notification publish success`) Logger.info(TAG, `onWorkStop notification publish success`)
}) })
} }
} }
``` ```
3. 在工程entry Module对应的ets目录(./entry/src/main/ets)下,新建一个目录并命名为workAbility。 3. 在工程entry Module对应的ets目录(./entry/src/main/ets)下,新建一个目录并命名为workAbility。
在workAbility目录下,新建一个eTS文件并命名为WorkTest.ets,实现延迟任务回调接口。 在workAbility目录下,新建一个eTS文件并命名为WorkTest.ets,实现延迟任务回调接口。
> 导入模块。 导入模块。
```ts ```ts
import { workAbility } from '@ohos/library' import { workAbility } from '@ohos/library'
``` ```
> 继承workAbility,实现WorkSchedulerExtension生命周期接口。 继承workAbility,实现WorkSchedulerExtension生命周期接口。
```ts ```ts
export default class WorkTest extends workAbility { export default class WorkTest extends workAbility {
onWorkStart(workInfo) { onWorkStart(workInfo) {
Logger.info(TAG, `onWorkStartTest start ${JSON.stringify(workInfo)}`) Logger.info(TAG, `onWorkStartTest start ${JSON.stringify(workInfo)}`)
super.onWorkStart(workInfo) super.onWorkStart(workInfo)
...@@ -101,23 +99,23 @@ export default class WorkTest extends workAbility { ...@@ -101,23 +99,23 @@ export default class WorkTest extends workAbility {
super.onWorkStop(workInfo) super.onWorkStop(workInfo)
Logger.info(TAG, `onWorkStop value`) Logger.info(TAG, `onWorkStop value`)
} }
} }
``` ```
### 开发延迟任务调度接口 ### 开发延迟任务调度接口
1. 在library对应的ets目录(./library/src/main/ets)下,新建ts文件并命名为DelayWork.ts,用于实现延迟任务API。 1. 在library对应的ets目录(./library/src/main/ets)下,新建ts文件并命名为DelayWork.ts,用于实现延迟任务API。
> 导入模块。 导入模块。
```ts ```ts
import workScheduler from '@ohos.resourceschedule.workScheduler' import workScheduler from '@ohos.resourceschedule.workScheduler'
``` ```
> 封装延迟任务注册、停止接口。 封装延迟任务注册、停止接口。
```ts ```ts
export default class DelayWork { export default class DelayWork {
private workInfo = { private workInfo = {
workId: 1, workId: 1,
networkType: workScheduler.NetworkType.NETWORK_TYPE_WIFI, networkType: workScheduler.NetworkType.NETWORK_TYPE_WIFI,
...@@ -146,20 +144,20 @@ export default class DelayWork { ...@@ -146,20 +144,20 @@ export default class DelayWork {
workScheduler.stopWork(this.workInfo, false) workScheduler.stopWork(this.workInfo, false)
Logger.info(TAG, `stopWork`) Logger.info(TAG, `stopWork`)
} }
} }
``` ```
3. 在工程entry Module对应的index页面(./entry/src/main/ets/pages/index.ets)下,增加“升级”按钮,调用library封装的延迟任务注册接口。 2. 在工程entry Module对应的index页面(./entry/src/main/ets/pages/index.ets)下,增加“升级”按钮,调用library封装的延迟任务注册接口。
> 导入模块。 导入模块。
```ts ```ts
import { workAbility } from '@ohos/library' import { workAbility } from '@ohos/library'
``` ```
> 增加“升级”按钮,调用library封装的延迟任务注册接口,传入bundleName和abilityName,其中bilityName为WorkTest。 增加“升级”按钮,调用library封装的延迟任务注册接口,传入bundleName和abilityName,其中bilityName为WorkTest。
```ts ```ts
Button($r('app.string.upgrade')) Button($r('app.string.upgrade'))
.width('60%') .width('60%')
.height(40) .height(40)
...@@ -167,15 +165,15 @@ import { workAbility } from '@ohos/library' ...@@ -167,15 +165,15 @@ import { workAbility } from '@ohos/library'
.onClick(() => { .onClick(() => {
this.work.startWork('ohos.samples.workscheduler', 'WorkTest') this.work.startWork('ohos.samples.workscheduler', 'WorkTest')
}) })
``` ```
> 在组件析构时,调用延迟任务停止接口。 在组件析构时,调用延迟任务停止接口。
```ts ```ts
aboutToDisappear() { aboutToDisappear() {
this.work.stopWork('ohos.samples.workscheduler', 'WorkTest') this.work.stopWork('ohos.samples.workscheduler', 'WorkTest')
} }
``` ```
### 配置文件 ### 配置文件
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册