You need to sign in or sign up before continuing.
device-usage-statistics-dev-guide.md 6.5 KB
Newer Older
Y
yupeng74@huawei.com 已提交
1
# 设备使用信息统计(API7)
W
wyuanchao 已提交
2

W
wyuanchao 已提交
3
## 场景介绍
W
wyuanchao 已提交
4

W
wyuanchao 已提交
5 6 7
设备使用信息统计,包括app usage/notification usage/system usage等使用统计。例如应用使用信息统计,用于保存和查询应用使用详情(app usage)、事件日志数据(event log)、应用分组(bundle group)情况。
部件缓存的应用记录(使用历史统计和使用事件记录)会在事件上报后30分钟内刷新到数据库持久化保存。

Z
zhangxin_T 已提交
8
根据设备的使用信息统计接口,开发者可以开发出健康管理类应用来实现个人设备健康使用功能,并向用户展示其个人设备的使用记录。
Z
zhangxin_T 已提交
9

W
wyuanchao 已提交
10 11 12
## 接口说明
注册相关接口包导入:
```js
W
wyuanchao 已提交
13
import stats from '@ohos.bundleState';
W
wyuanchao 已提交
14
```
W
wyuanchao 已提交
15 16 17 18 19

**表1** 设备使用信息统计主要接口

| 接口名 | 描述 |
| -------- | -------- |
W
wyuanchao 已提交
20 21 22 23
| function queryBundleActiveStates(begin: number, end: number, callback: AsyncCallback<Array<BundleActiveState>>): void | 通过指定起始和结束时间查询所有应用的事件集合。 |
| function queryBundleStateInfos(begin: number, end: number, callback: AsyncCallback<BundleActiveInfoResponse>): void | 通过指定起始和结束时间查询应用使用时长统计信息。 |
| function queryCurrentBundleActiveStates(begin: number, end: number, callback: AsyncCallback<Array<BundleActiveState>>): void | 通过指定起始和结束时间查询当前应用的事件集合。 |
| function queryBundleStateInfoByInterval(byInterval: IntervalType, begin: number, end: number, callback: AsyncCallback<Array<BundleStateInfo>>): void | 通过指定时间段间隔(天、周、月、年)查询应用使用时长统计信息。 |
Y
yupeng74@huawei.com 已提交
24 25
| function queryAppUsagePriorityGroup(callback: AsyncCallback<number>): void | 查询当前应用的使用优先级群组。callback形式。 |
| function queryAppUsagePriorityGroup(): Promise<number>; | 查询当前应用的使用优先级群组。promise形式。 |
W
wyuanchao 已提交
26
| function isIdleState(bundleName: string, callback: AsyncCallback<boolean>): void | 判断指定Bundle Name的应用当前是否是空闲状态。 |
W
wyuanchao 已提交
27 28 29

## 开发步骤

Y
yupeng74@huawei.com 已提交
30 31 32
1. 获取设备使用信息之前,需要检查是否已经配置请求相应的权限。
    系统提供的设备使用信息统计的权限是ohos.permission.BUNDLE_ACTIVE_INFO
    具体配置方式请参考[权限申请声明](../security/accesstoken-guidelines.md)
W
wyuanchao 已提交
33

Y
yupeng74@huawei.com 已提交
34
2. 通过指定起始和结束时间查询所有应用的事件集合,需要配置ohos.permission.BUNDLE_ACTIVE_INFO权限。
W
wyuanchao 已提交
35 36

    ```js
W
wyuanchao 已提交
37
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
38

39
    stats.queryBundleActiveStates(0, 20000000000000).then(res => {
W
wyuanchao 已提交
40
        console.log('BUNDLE_ACTIVE queryBundleActiveStates promise success.');
W
wyuanchao 已提交
41
        for (let i = 0; i < res.length; i++) {
W
wyuanchao 已提交
42 43
            console.log('BUNDLE_ACTIVE queryBundleActiveStates promise number : ' + (i + 1));
            console.log('BUNDLE_ACTIVE queryBundleActiveStates promise result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
44
        }
45
    }).catch(err => {
W
wyuanchao 已提交
46
        console.log('BUNDLE_ACTIVE queryBundleActiveStates promise failed, because: ' + err.code);
W
wyuanchao 已提交
47 48 49
    });
    ```

Y
yupeng74@huawei.com 已提交
50
3. 通过指定起始和结束时间查询应用使用时长统计信息,需要配置ohos.permission.BUNDLE_ACTIVE_INFO权限。
W
wyuanchao 已提交
51 52

    ```js
W
wyuanchao 已提交
53
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
54

55
    stats.queryBundleStateInfos(0, 20000000000000).then(res => {
W
wyuanchao 已提交
56 57
        console.log('BUNDLE_ACTIVE queryBundleStateInfos promise success.');
        let i = 1;
W
wyuanchao 已提交
58
        for (let key in res){
W
wyuanchao 已提交
59 60 61
            console.log('BUNDLE_ACTIVE queryBundleStateInfos promise number : ' + i);
            console.log('BUNDLE_ACTIVE queryBundleStateInfos promise result ' + JSON.stringify(res[key]));
            i++;
W
wyuanchao 已提交
62
        }
63
    }).catch(err => {
W
wyuanchao 已提交
64
        console.log('BUNDLE_ACTIVE queryBundleStateInfos promise failed, because: ' + err.code);
W
wyuanchao 已提交
65 66 67
    });
    ```

Y
yupeng74@huawei.com 已提交
68
4. 通过指定起始和结束时间查询当前应用的事件集合,不需要配置权限。
W
wyuanchao 已提交
69 70

    ```js
W
wyuanchao 已提交
71
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
72

73
    stats.queryCurrentBundleActiveStates(0, 20000000000000).then(res => {
W
wyuanchao 已提交
74
        console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates promise success.');
W
wyuanchao 已提交
75
        for (let i = 0; i < res.length; i++) {
W
wyuanchao 已提交
76 77
            console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates promise number : ' + (i + 1));
            console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates promise result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
78
        }
79
    }).catch(err => {
W
wyuanchao 已提交
80
        console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates promise failed, because: ' + err.code);
W
wyuanchao 已提交
81 82 83
    });
    ```

Y
yupeng74@huawei.com 已提交
84
5. 通过指定时间段间隔(天、周、月、年)查询应用使用时长统计信息,需要配置ohos.permission.BUNDLE_ACTIVE_INFO权限。
W
wyuanchao 已提交
85 86

    ```js
W
wyuanchao 已提交
87
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
88

89
    stats.queryBundleStateInfoByInterval(0, 0, 20000000000000).then(res => {
W
wyuanchao 已提交
90
        console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval promise success.');
W
wyuanchao 已提交
91
        for (let i = 0; i < res.length; i++) {
W
wyuanchao 已提交
92 93
            console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval promise number : ' + (i + 1));
            console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval promise result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
94
        }
95
    }).catch(err => {
W
wyuanchao 已提交
96
        console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval promise failed, because: ' + err.code);
W
wyuanchao 已提交
97 98 99 100
    });

    ```

Y
yupeng74@huawei.com 已提交
101
6. 查询(无参)当前调用者应用的使用优先级群组,不需要配置权限。
W
wyuanchao 已提交
102 103

    ```js
W
wyuanchao 已提交
104
    import stats from '@ohos.bundleState'
105

106
    stats.queryAppUsagePriorityGroup().then(res => {
W
wyuanchao 已提交
107
        console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup promise succeeded. result: ' + JSON.stringify(res));
108
    }).catch(err => {
W
wyuanchao 已提交
109
        console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup promise failed. because: ' + err.code);
W
wyuanchao 已提交
110 111
    });
    ```
112

Y
yupeng74@huawei.com 已提交
113
7. 判断指定Bundle Name的应用当前是否是空闲状态,需要配置ohos.permission.BUNDLE_ACTIVE_INFO权限,三方应用只能查询自身的空闲状态。
W
wyuanchao 已提交
114 115

    ```js
W
wyuanchao 已提交
116
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
117

118
    stats.isIdleState("com.ohos.camera").then(res => {
W
wyuanchao 已提交
119
        console.log('BUNDLE_ACTIVE isIdleState promise succeeded, result: ' + JSON.stringify(res));
120
    }).catch(err => {
W
wyuanchao 已提交
121
        console.log('BUNDLE_ACTIVE isIdleState promise failed, because: ' + err.code);
W
wyuanchao 已提交
122 123
    });

H
houdisheng 已提交
124
    ```
125 126
## 相关实例
针对设备使用信息统计,有以下相关实例可供参考:
127
- [`DeviceUsageStatistics`:设备使用信息统计(ArkTS)(API8)(Full SDK)](https://gitee.com/openharmony/applications_app_samples/tree/master/device/DeviceUsageStatistics)
Y
yupeng74@huawei.com 已提交
128