提交 172cf0c1 编写于 作者: G geraltxu

设备待机续航部件开发指南修改

Signed-off-by: Nxufanghan <xufanghan@huawei.com>
上级 644b42df
# 设备待机空闲部件开发指南
# 设备待机续航部件开发指南
## 场景介绍
当前设备在待机状态及睡眠状态,应用不会被冻结、任务不会被延迟、时钟时间不会变慢、CPU锁不会释放、网络不会停止,导致灭屏功耗大
设备灭屏/锁屏情况下,保持一段时间后进入待机空闲模式,限制后台应用使用资源,降低功耗。<br>
当前设备在灭屏进入待机睡眠前,应用不会被冻结、Work任务不会被延迟、Timer时间不会变慢、CPU锁不会释放、应用网络访问不会停止,导致设备灭屏功耗大,影响整机续航
因此,在进入待机空闲状态下,需要限制后台应用使用资源,降低整机功耗。<br>
解决以下场景<br>
一、采集系统设备进入待机空闲特征<br>
一、采集系统设备进入待机空闲特征,进入待机时机,退出待机条件<br>
二、检测设备进入浅睡眠状态和深睡眠状态<br>
三、设备每隔一段时间暂停睡眠,进入维护状态<br>
四、检测到设备进入待机空闲状态,触发资源管控
......@@ -12,26 +12,14 @@
## 待机低续航模式介绍
待机低续航模式会延迟应用后台cpu和网络活动,从而延长电池续航时间。
<br>包括:
<br>1.应用限网:限制访问网络
<br>1.应用限网:限制应用访问网络
<br>2.work待机任务:延迟应用的work任务响应
<br>3.running_lock锁:释放应用
<br>3.running_lock锁:释放应用申请的cpu running_lock
<br>4.Timer响应:延迟应用的timer响应
## 接口说明
### 一、返回当前是否进入待机功耗续航模式
isDeviceInStandby()
<br>
功能描述:返回当前是否进入待机低功耗续航模式。
<br>
举例:push客户端应用获取待机状态管控消息推送缓存
### 二、获取豁免信息
getExemptionListApps()
<br>
功能描述:获取豁免信息
<br>
举例:push客户端应用获取push限网豁免名单
### 三、更新调用者豁免信息
applyExemptionAppResource()、unapplyExemptionAppResource()
<br>
功能描述:更新调用者豁免信息
<br>
举例:针对系统应用可以申请临时豁免,临时放行待机状态管控该应用使用资源限制
一、应用查询待机空闲状态接口<br>
isDeviceInStandby
二、应用申请待机空闲状态正常使用资源的接口<br>
getExemptedApps
requestExemptionResource
releaseExemptionResource
# @ohos.resourceschedule.deviceStandby(设备待机空闲部件功能)
本模块提供设备待机空闲部件管理功能
<br>
API使用场景:
<br>
如果用户长时间没有主动使用设备,且屏幕已关闭,则系统会使设备进入待机低功耗续航模式。待机续航模式会延迟应用后台CPU和网络活动,从而延长电池续航时间。 包括:
<br>
1、应用限网:通过iptable防火墙限制后台应用访问网络
<br>
1、应用限网:限制后台应用访问网络
2、Work待机任务:延迟应用的work任务响应
<br>
3、running_lock锁:临时释放应用的background running_lock锁
<br>
4、Timer响应:延迟应用的timer响应
<br>
5、待规划:停止wifi扫描、停止蓝牙扫描、云同步账户等
> **说明:**
> - 本模块首批接口从API version 10开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
......@@ -24,11 +16,8 @@ import deviceStandby from '@ohos.resourceschedule.deviceStandby';
```
## deviceStandby.isDeviceInStandby
function isDeviceInStandby(callback: AsyncCallback<boolean>): void;
<br>
当前设备是否进入待机低功耗续航模式
<br>
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby.Idle
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby
**参数**
| 参数名 | 类型 | 必填 | 说明 |
......@@ -36,7 +25,6 @@ function isDeviceInStandby(callback: AsyncCallback<boolean>): void;
| callback | Callback&lt;void&gt; | 是 | 延迟即将超时的回调函数,一般在超时前6秒通过此回调通知应用。 |
**错误码**
以下错误码的详细介绍请参见[@ohos.resourceschedule.backgroundTaskManager (后台任务管理)](../errorcodes/errorcode-backgroundTaskMgr.md)错误码。
| 错误码ID | 错误信息 |
......@@ -45,17 +33,14 @@ function isDeviceInStandby(callback: AsyncCallback<boolean>): void;
| 401 | Parameter error. |
| 9800001 | Memory operation failed. |
| 9800002 | Parcel operation failed. |
| 9800003 | IPC failed. | |
| 9800003 | IPC failed. |
| 9800004 | System service operation failed. |
| 18700001 | Caller information verification failed when applying for efficiency resources. |
## deviceStandby.isDeviceInStandby
function isDeviceInStandby(): Promise&lt;boolean&gt;
<br>
当前设备是否进入待机低功耗续航模式
<br>
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby.Idle
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby
**返回值**
| 类型 | 说明 |
......@@ -71,17 +56,14 @@ function isDeviceInStandby(): Promise&lt;boolean&gt;
| 401 | Parameter error. |
| 9800001 | Memory operation failed. |
| 9800002 | Parcel operation failed. |
| 9800003 | IPC failed. | |
| 9800003 | IPC failed. |
| 9800004 | System service operation failed. |
| 18700001 | Caller information verification failed when applying for efficiency resources. |
## deviceStandby.getExemptionListApps
function getExemptionListApps(resourceTypes: number, callback: AsyncCallback<Array&lt;ExemptionAppInfo&gt;>): void;
<br>
## deviceStandby.getExemptedApps
function getExemptedApps(resourceTypes: number, callback: AsyncCallback<Array&lt;ExemptedAppInfo&gt;>): void;
返回豁免应用名单
<br>
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby.Exemption
<br>
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby
**系统API:** 此接口为系统接口。
**参数**
......@@ -89,7 +71,7 @@ function getExemptionListApps(resourceTypes: number, callback: AsyncCallback<Arr
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------------------- | ---- | ------------------------------ |
| resourceTypes |number | 是 | 资源类型,具体结构见文末枚举 |
| callback | AsyncCallback<Array&lt;ExemptionAppInfo&gt;> | 是 | 回调函数,具体结构见文末 |
| callback | AsyncCallback<Array&lt;ExemptedAppInfo&gt;> | 是 | 回调函数,具体结构见文末 |
**错误码**
......@@ -102,18 +84,14 @@ function getExemptionListApps(resourceTypes: number, callback: AsyncCallback<Arr
| 401 | Parameter error. |
| 9800001 | Memory operation failed. |
| 9800002 | Parcel operation failed. |
| 9800003 | IPC failed. | |
| 9800003 | IPC failed. |
| 9800004 | System service operation failed. |
| 18700001 | Caller information verification failed when applying for efficiency resources. |
## deviceStandby.getExemptionListApps
function getExemptionListApps(resourceTypes: number): Promise<Array&lt;ExemptionAppInfo&gt;>;
<br>
## deviceStandby.getExemptedApps
function getExemptedApps(resourceTypes: number): Promise<Array&lt;ExemptedAppInfo&gt;>;
返回豁免应用名单
<br>
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby.Exemption
<br>
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby
**系统API:** 此接口为系统接口。
**参数**
| 参数名 | 类型 | 必填 | 说明 |
......@@ -124,7 +102,7 @@ function getExemptionListApps(resourceTypes: number): Promise<Array&lt;Exemption
| 类型 | 说明 |
| --------------------- | ---------------------------------------- |
| Promise<Array&lt;ExemptionAppInfo&gt;> | 指定的Promise回调方法。返回豁免应用名单,具体结构见文末|
| Promise<Array&lt;ExemptedAppInfo&gt;> | 指定的Promise回调方法。返回豁免应用名单,具体结构见文末|
**错误码**
......@@ -137,19 +115,15 @@ function getExemptionListApps(resourceTypes: number): Promise<Array&lt;Exemption
| 401 | Parameter error. |
| 9800001 | Memory operation failed. |
| 9800002 | Parcel operation failed. |
| 9800003 | IPC failed. | |
| 9800003 | IPC failed. |
| 9800004 | System service operation failed. |
| 18700001 | Caller information verification failed when applying for efficiency resources. |
## deviceStandby.applyExemptionAppResource
function applyExemptionAppResource(request: ResourceRequest): void;
<br>
## deviceStandby.requestExemptionResource
function requestExemptionResource(request: ResourceRequest): void;
订阅申请豁免
<br>
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby.Exemption
<br>
**系统API:** 此接口为系统接口。
**参数**
| 参数名 | 类型 | 必填 | 说明 |
......@@ -167,17 +141,14 @@ function applyExemptionAppResource(request: ResourceRequest): void;
| 401 | Parameter error. |
| 9800001 | Memory operation failed. |
| 9800002 | Parcel operation failed. |
| 9800003 | IPC failed. | |
| 9800003 | IPC failed. |
| 9800004 | System service operation failed. |
| 18700001 | Caller information verification failed when applying for efficiency resources. |
## deviceStandby.unapplyExemptionAppResource
function unapplyExemptionAppResource(request: ResourceRequest): void;
<br>
## deviceStandby.releaseExemptionResource
function releaseExemptionResource(request: ResourceRequest): void;
去除订阅申请豁免
<br>
**系统能力:** SystemCapability.ResourceSchedule.DeviceStandby.Exemption
<br>
**系统API:** 此接口为系统接口。
**参数**
......@@ -197,7 +168,7 @@ function unapplyExemptionAppResource(request: ResourceRequest): void;
| 401 | Parameter error. |
| 9800001 | Memory operation failed. |
| 9800002 | Parcel operation failed. |
| 9800003 | IPC failed. | |
| 9800003 | IPC failed. |
| 9800004 | System service operation failed. |
| 18700001 | Caller information verification failed when applying for efficiency resources. |
......@@ -216,7 +187,7 @@ The resource type of exemption application.
|PUSH |1 << 5 |The resource for non-standby pushkit.|
|FREEZE |1 << 6 |The resource for non-standby freezing application.|
### ExemptionAppInfo
### ExemptedAppInfo
The information of exemption application.
<br>
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册