Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
4249800b
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
4249800b
编写于
1月 12, 2023
作者:
O
openharmony_ci
提交者:
Gitee
1月 12, 2023
浏览文件
操作
浏览文件
下载
差异文件
!13253 WorkSchedulerExtensionAbility开发指南
Merge pull request !13253 from 朱天怡/master
上级
aad022f3
e42eb246
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
206 addition
and
2 deletion
+206
-2
zh-cn/application-dev/task-management/Readme-CN.md
zh-cn/application-dev/task-management/Readme-CN.md
+1
-0
zh-cn/application-dev/task-management/figures/WorkSchedulerExtensionAbility.png
...task-management/figures/WorkSchedulerExtensionAbility.png
+0
-0
zh-cn/application-dev/task-management/work-scheduler-dev-guide.md
...plication-dev/task-management/work-scheduler-dev-guide.md
+2
-2
zh-cn/application-dev/task-management/workscheduler-extensionability.md
...ion-dev/task-management/workscheduler-extensionability.md
+203
-0
未找到文件。
zh-cn/application-dev/task-management/Readme-CN.md
浏览文件 @
4249800b
...
...
@@ -5,6 +5,7 @@
-
[
短时任务开发指导
](
transient-task-dev-guide.md
)
-
[
长时任务开发指导
](
continuous-task-dev-guide.md
)
-
[
延迟任务开发指导
](
work-scheduler-dev-guide.md
)
-
[
延迟任务回调能力开发指导
](
workscheduler-extensionability.md
)
-
[
申请能效资源开发指导
](
efficiency-resources-apply-dev-guide.md
)
-
后台代理提醒
...
...
zh-cn/application-dev/task-management/figures/WorkSchedulerExtensionAbility.png
0 → 100644
浏览文件 @
4249800b
32.7 KB
zh-cn/application-dev/task-management/work-scheduler-dev-guide.md
浏览文件 @
4249800b
...
...
@@ -2,7 +2,7 @@
## 场景介绍
应用要执行对实时性要求不高的任务或持久性任务的时候,比如设备空闲时候做一次数据学习等场景,可以使用延迟调度任务,该机制在满足应用设定条件的时候,会根据系统当前状态,如内存、功耗、温度等统一决策调度时间。延迟任务调度约束见
[
延迟任务调度约束
](
./background-task-overview.md#延迟任务调度约束
)
。
应用要执行对实时性要求不高的任务或持久性任务的时候,比如设备空闲时候做一次数据学习等场景,可以使用延迟调度任务,该机制在满足应用设定条件的时候,会根据系统当前状态,如内存、功耗、温度等统一决策调度时间
,
[
WorkSchedulerExtensionAbility
](
./workscheduler-extensionability.md
)
提供了延迟任务回调拓展能力
。延迟任务调度约束见
[
延迟任务调度约束
](
./background-task-overview.md#延迟任务调度约束
)
。
## 接口说明
...
...
@@ -61,7 +61,7 @@ import workScheduler from '@ohos.resourceschedule.workScheduler';
import
WorkSchedulerExtensionAbility
from
'
@ohos.WorkSchedulerExtensionAbility
'
;
```
2、开发对应的ExtensionAbility,用于回调执行具体的延迟任务。关于ExtensionAbility的介绍,参考
[
ExtensionAbility机制
](
../application-models/extensionability-overview.md
)
。
2、开发对应的ExtensionAbility,用于回调执行具体的延迟任务。关于ExtensionAbility的介绍,参考
[
ExtensionAbility机制
](
../application-models/extensionability-overview.md
)
和
[
WorkSchedulerExtensionAbility开发指导
](
./workscheduler-extensionability.md
)
。
```
ts
import
WorkSchedulerExtensionAbility
from
'
@ohos.WorkSchedulerExtensionAbility
'
;
...
...
zh-cn/application-dev/task-management/workscheduler-extensionability.md
0 → 100644
浏览文件 @
4249800b
# 延迟任务回调能力开发指导(WorkSchedulerExtensionAbility)
对于实时性要求不高的任务或持久性任务,可以使用延迟调度任务,该机制会在应用满足应用设定条件(包括网络类型、充电类型、存储状态、电池状态、定时状态)时,根据系统当前状态,由系统统一决策调度时间。
WorkSchedulerExtensionAbility提供了延迟任务回调能力,在延迟任务开始和结束时,系统会调用回调接口来处理任务逻辑,开发者可在回调接口里面编写自己的任务逻辑。
## 运作机制
延迟任务调度运作机制如图1所示。
**图1**
延迟任务调度运作机制
![
WorkSchedulerExtensionAbility
](
figures/WorkSchedulerExtensionAbility.png
)
应用通过
[
延迟任务API
](
../reference/apis/js-apis-resourceschedule-workScheduler.md
)
注册、删除、查询任务。
应用服务侧进行条件检测和判断,若满足条件,则回调WorkSchedulerExtensionAbility拉起应用,执行onWorkStart、onWorkStop回调接口。
## 接口说明
WorkSchedulerExtensionAbility类拥有如下API接口,具体的API介绍详见
[
接口文档
](
../reference/apis/js-apis-app-form-formExtensionAbility.md
)
。
| 接口名 | 描述 |
| -------- | -------- |
| onWorkStart(work: workScheduler.WorkInfo): void | 延迟任务调度开始回调。 |
| onWorkStop(work: workScheduler.WorkInfo): void | 延迟任务调度结束回调。 |
## 开发步骤
在DevEco Studio工程中新建一个WorkScheduler工程,主要涉及如下关键步骤:
-
[
实现延迟任务回调拓展能力
](
#实现延迟任务回调拓展能力
)
:开发延迟任务生命周期回调接口WorkSchedulerExtensionAbility。
-
[
实现延迟任务调度能力
](
#实现延迟任务调度能力
)
:开发延迟任务API,实现延迟任务注册、停止等功能。
-
[
配置文件
](
#配置文件
)
:配置应用配置文件module.json5。
### 实现延迟任务回调拓展能力
1.
在工程根目录新建Module,模板选择为Ohos Library,命名为library。
2.
在library对应的ets目录(./library/src/main/ets)下,新建ArkTS文件并命名为workAbility.ets,用于实现延迟任务回调接口。
导入模块。
```
ts
import
WorkSchedulerExtensionAbility
from
'
@ohos.WorkSchedulerExtensionAbility
'
```
实现WorkSchedulerExtension生命周期接口。
```
ts
export
default
class
workAbility
extends
WorkSchedulerExtensionAbility
{
// 延迟任务开始回调
onWorkStart
(
workInfo
)
{
console
.
log
(
`onWorkStart CommonEvent publish start
${
JSON
.
stringify
(
workInfo
)}
`
)
// 发送升级通知
let
notificationRequest
=
notification
.
getNotificationContentBasic
(
'
upgrade
'
,
upgradeMessage
,
''
)
notification
.
publish
(
notificationRequest
,
(
err
)
=>
{
if
(
err
)
{
console
.
log
(
`onWorkStart notification publish err
${
JSON
.
stringify
(
err
)}
`
)
}
console
.
log
(
`onWorkStart notification publish success`
)
})
}
// 延迟任务结束回调
onWorkStop
(
workInfo
)
{
// 发送升级完成通知
let
notificationRequest
=
notification
.
getNotificationContentBasic
(
'
upgrade
'
,
'
upgrade success
'
,
''
)
notification
.
publish
(
notificationRequest
,
(
err
)
=>
{
if
(
err
)
{
console
.
log
(
`onWorkStop notification publish err
${
JSON
.
stringify
(
err
)}
`
)
}
console
.
log
(
`onWorkStop notification publish success`
)
})
}
}
```
3.
在工程entry Module对应的ets目录(./entry/src/main/ets)下,新建一个目录并命名为workAbility。
在workAbility目录下,新建一个ArkTS文件并命名为WorkTest.ets,实现延迟任务回调接口。
导入模块。
```
ts
import
{
workAbility
}
from
'
@ohos/library
'
```
继承workAbility,实现WorkSchedulerExtension生命周期接口。
```
ts
export
default
class
WorkTest
extends
workAbility
{
onWorkStart
(
workInfo
)
{
console
.
log
(
`onWorkStartTest start
${
JSON
.
stringify
(
workInfo
)}
`
)
super
.
onWorkStart
(
workInfo
)
}
onWorkStopTest
(
workInfo
)
{
super
.
onWorkStop
(
workInfo
)
console
.
log
(
`onWorkStop value`
)
}
}
```
### 实现延迟任务调度能力
1.
在library对应的ets目录(./library/src/main/ets)下,新建TypeScript文件并命名为DelayWork.ts,用于实现延迟任务API。
导入模块。
```
ts
import
workScheduler
from
'
@ohos.resourceschedule.workScheduler
'
```
封装延迟任务注册、停止接口。
```
ts
export
default
class
DelayWork
{
private
workInfo
=
{
workId
:
1
,
networkType
:
workScheduler
.
NetworkType
.
NETWORK_TYPE_WIFI
,
bundleName
:
''
,
abilityName
:
''
}
// 注册延迟调度任务
startWork
(
bundleName
:
string
,
abilityName
:
string
)
{
this
.
workInfo
.
bundleName
=
bundleName
this
.
workInfo
.
abilityName
=
abilityName
try
{
workScheduler
.
startWork
(
this
.
workInfo
)
console
.
log
(
`startWork success`
)
}
catch
(
error
)
{
Logger
.
error
(
TAG
,
`startWork startwork failed. code is
${
error
.
code
}
message is
${
error
.
message
}
`
)
prompt
.
showToast
({
message
:
`
${
error
.
message
}
`
})
}
}
// 停止延迟调度任务
stopWork
(
bundleName
:
string
,
abilityName
:
string
)
{
this
.
workInfo
.
bundleName
=
bundleName
this
.
workInfo
.
abilityName
=
abilityName
workScheduler
.
stopWork
(
this
.
workInfo
,
false
)
console
.
log
(
`stopWork`
)
}
}
```
2.
在工程entry Module对应的index页面(./entry/src/main/ets/pages/index.ets)下,增加“升级”按钮,调用library封装的延迟任务注册接口。
导入模块。
```
ts
import
{
workAbility
}
from
'
@ohos/library
'
```
增加“升级”按钮,调用library封装的延迟任务注册接口,传入bundleName和abilityName,其中bilityName为WorkTest。
```
ts
Button
(
$r
(
'
app.string.upgrade
'
))
.
width
(
'
60%
'
)
.
height
(
40
)
.
fontSize
(
30
)
.
onClick
(()
=>
{
this
.
work
.
startWork
(
'
ohos.samples.workscheduler
'
,
'
WorkTest
'
)
})
```
在组件析构时,调用延迟任务停止接口。
```
ts
aboutToDisappear
()
{
this
.
work
.
stopWork
(
'
ohos.samples.workscheduler
'
,
'
WorkTest
'
)
}
```
### 配置文件
1.
在工程entry Module对应的
[
module.json5配置文件
](
../quick-start/module-configuration-file.md
)
中注册WorkSchedulerExtensionAbility,type标签需要设置为“workScheduler”,srcEntrance标签表示当前ExtensionAbility组件所对应的代码路径。
```
json
{
"module"
:
{
"extensionAbilities"
:
[
{
"name"
:
"WorkTest"
,
"srcEntrance"
:
"./ets/workAbility/WorkTest.ets"
,
"label"
:
"$string:WorkSchedulerExtensionAbility_label"
,
"description"
:
"$string:WorkSchedulerExtensionAbility_desc"
,
"type"
:
"workScheduler"
}
]
}
}
```
## 相关实例
针对WorkSchedulerExtensionAbility开发,有以下相关示例可供参考:
[
WorkScheduler的创建与使用(ArkTS)(API9)
](
https://gitee.com/openharmony/applications_app_samples/tree/master/ResourcesSchedule/WorkScheduler
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录