Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
e4bb793f
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看板
未验证
提交
e4bb793f
编写于
1月 10, 2023
作者:
朱
朱天怡
提交者:
Gitee
1月 10, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修改
Signed-off-by:
N
朱天怡
<
zhutianyi2@huawei.com
>
上级
a8cfeb2d
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
112 addition
and
114 deletion
+112
-114
zh-cn/application-dev/task-management/workscheduler-extensionability.md
...ion-dev/task-management/workscheduler-extensionability.md
+112
-114
未找到文件。
zh-cn/application-dev/task-management/workscheduler-extensionability.md
浏览文件 @
e4bb793f
#
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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录