device-usage-statistics-dev-guide.md 12.1 KB
Newer Older
W
wyuanchao 已提交
1 2
## 设备使用信息统计

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

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

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

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

| 接口名 | 描述 |
| -------- | -------- |
W
wyuanchao 已提交
18 19 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 | 通过指定时间段间隔(天、周、月、年)查询应用使用时长统计信息。 |
| function queryAppUsagePriorityGroup(callback: AsyncCallback<number>): void | 查询(返回)当前调用者应用的使用优先级群组。 |
| function isIdleState(bundleName: string, callback: AsyncCallback<boolean>): void | 判断指定Bundle Name的应用当前是否是空闲状态。 |
H
houdisheng 已提交
24
| function getRecentlyUsedModules(maxNum: number, callback: AsyncCallback<BundleActiveModuleInfo>): void | 根据maxNum,查询FA使用记录,返回不超过maxNum条FA使用记录。 |
W
wyuanchao 已提交
25 26 27

## 开发步骤

W
wyuanchao 已提交
28
1. 在config.json文件中配置设备使用信息统计权限。
W
wyuanchao 已提交
29 30 31 32 33 34 35 36 37 38 39 40 41

    ```json
    "module": {
        "package": "com.example.deviceUsageStatistics",
        ...,
        "reqPermissions": [
            {
            "name": "ohos.permission.BUNDLE_ACTIVE_INFO"
            }
        ]
    }
    ```

W
wyuanchao 已提交
42
2. 通过指定起始和结束时间查询所有应用的事件集合,config.json中需要配置权限:ohos.permission.BUNDLE_ACTIVE_INFO。
W
wyuanchao 已提交
43 44

    ```js
W
wyuanchao 已提交
45
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
46 47 48

    // 异步方法promise方式
    stats.queryBundleActiveStates(0, 20000000000000).then( res => {
W
wyuanchao 已提交
49
        console.log('BUNDLE_ACTIVE queryBundleActiveStates promise success.');
W
wyuanchao 已提交
50
        for (let i = 0; i < res.length; i++) {
W
wyuanchao 已提交
51 52
            console.log('BUNDLE_ACTIVE queryBundleActiveStates promise number : ' + (i + 1));
            console.log('BUNDLE_ACTIVE queryBundleActiveStates promise result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
53 54
        }
    }).catch( err => {
W
wyuanchao 已提交
55
        console.log('BUNDLE_ACTIVE queryBundleActiveStates promise failed, because: ' + err.code);
W
wyuanchao 已提交
56 57 58
    });

    // 异步方法callback方式
W
wyuanchao 已提交
59
    stats.queryBundleActiveStates(0, 20000000000000, (err, res) => {
W
wyuanchao 已提交
60 61 62
        if (err) {
            console.log('BUNDLE_ACTIVE queryBundleActiveStates callback failed, because: ' + err.code);
        } else {
W
wyuanchao 已提交
63 64 65 66
            console.log('BUNDLE_ACTIVE queryBundleActiveStates callback success.');
            for (let i = 0; i < res.length; i++) {
                console.log('BUNDLE_ACTIVE queryBundleActiveStates callback number : ' + (i + 1));
                console.log('BUNDLE_ACTIVE queryBundleActiveStates callback result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
67
            }
W
wyuanchao 已提交
68 69
        }
    });
W
wyuanchao 已提交
70 71
    ```

W
wyuanchao 已提交
72
3. 通过指定起始和结束时间查询应用使用时长统计信息,config.json中需要配置权限:ohos.permission.BUNDLE_ACTIVE_INFO。
W
wyuanchao 已提交
73 74

    ```js
W
wyuanchao 已提交
75
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
76 77 78

    // 异步方法promise方式
    stats.queryBundleStateInfos(0, 20000000000000).then( res => {
W
wyuanchao 已提交
79 80
        console.log('BUNDLE_ACTIVE queryBundleStateInfos promise success.');
        let i = 1;
W
wyuanchao 已提交
81
        for (let key in res){
W
wyuanchao 已提交
82 83 84
            console.log('BUNDLE_ACTIVE queryBundleStateInfos promise number : ' + i);
            console.log('BUNDLE_ACTIVE queryBundleStateInfos promise result ' + JSON.stringify(res[key]));
            i++;
W
wyuanchao 已提交
85 86
        }
    }).catch( err => {
W
wyuanchao 已提交
87
        console.log('BUNDLE_ACTIVE queryBundleStateInfos promise failed, because: ' + err.code);
W
wyuanchao 已提交
88 89 90
    });

    // 异步方法callback方式
W
wyuanchao 已提交
91
    stats.queryBundleStateInfos(0, 20000000000000, (err, res) => {
W
wyuanchao 已提交
92 93 94
        if (err) {
            console.log('BUNDLE_ACTIVE queryBundleStateInfos callback failed, because: ' + err.code);
        } else {
W
wyuanchao 已提交
95 96 97 98 99 100
            console.log('BUNDLE_ACTIVE queryBundleStateInfos callback success.');
            let i = 1;
            for(let key in res){
                console.log('BUNDLE_ACTIVE queryBundleStateInfos callback number : ' + i);
                console.log('BUNDLE_ACTIVE queryBundleStateInfos callback result ' + JSON.stringify(res[key]));
                i++;
W
wyuanchao 已提交
101
            }
W
wyuanchao 已提交
102 103
        }
    });
W
wyuanchao 已提交
104 105
    ```

W
wyuanchao 已提交
106
4. 通过指定起始和结束时间查询当前应用的事件集合,config.json中不需要配置权限。
W
wyuanchao 已提交
107 108

    ```js
W
wyuanchao 已提交
109
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
110 111 112

    // 异步方法promise方式
    stats.queryCurrentBundleActiveStates(0, 20000000000000).then( res => {
W
wyuanchao 已提交
113
        console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates promise success.');
W
wyuanchao 已提交
114
        for (let i = 0; i < res.length; i++) {
W
wyuanchao 已提交
115 116
            console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates promise number : ' + (i + 1));
            console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates promise result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
117 118
        }
    }).catch( err => {
W
wyuanchao 已提交
119
        console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates promise failed, because: ' + err.code);
W
wyuanchao 已提交
120 121 122
    });

    // 异步方法callback方式
W
wyuanchao 已提交
123
    stats.queryCurrentBundleActiveStates(0, 20000000000000, (err, res) => {
W
wyuanchao 已提交
124 125 126
        if (err) {
            console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates callback failed, because: ' + err.code);
        } else {
W
wyuanchao 已提交
127 128 129 130
            console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates callback success.');
            for (let i = 0; i < res.length; i++) {
                console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates callback number : ' + (i + 1));
                console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates callback result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
131
            }
W
wyuanchao 已提交
132 133
        }
    });
W
wyuanchao 已提交
134 135
    ```

W
wyuanchao 已提交
136
5. 通过指定时间段间隔(天、周、月、年)查询应用使用时长统计信息,config.json中需要配置权限:ohos.permission.BUNDLE_ACTIVE_INFO。
W
wyuanchao 已提交
137 138

    ```js
W
wyuanchao 已提交
139
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
140 141 142

    // 异步方法promise方式
    stats.queryBundleStateInfoByInterval(0, 0, 20000000000000).then( res => {
W
wyuanchao 已提交
143
        console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval promise success.');
W
wyuanchao 已提交
144
        for (let i = 0; i < res.length; i++) {
W
wyuanchao 已提交
145 146
            console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval promise number : ' + (i + 1));
            console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval promise result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
147 148
        }
    }).catch( err => {
W
wyuanchao 已提交
149
        console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval promise failed, because: ' + err.code);
W
wyuanchao 已提交
150 151 152
    });

    // 异步方法callback方式
W
wyuanchao 已提交
153
    stats.queryBundleStateInfoByInterval(0, 0, 20000000000000, (err, res) => {
W
wyuanchao 已提交
154 155 156
        if (err) {
            console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval callback failed, because: ' + err.code);
        } else {
W
wyuanchao 已提交
157 158 159 160
            console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval callback success.');
            for (let i = 0; i < res.length; i++) {
                console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval callback number : ' + (i + 1));
                console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval callback result ' + JSON.stringify(res[i]));
W
wyuanchao 已提交
161
            }
W
wyuanchao 已提交
162 163
        }
    });
W
wyuanchao 已提交
164 165
    ```

W
wyuanchao 已提交
166
6. 查询(返回)当前调用者应用的使用优先级群组,config.json中不需要配置权限。
W
wyuanchao 已提交
167 168

    ```js
W
wyuanchao 已提交
169
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
170 171 172

    // 异步方法promise方式
    stats.queryAppUsagePriorityGroup().then( res => {
W
wyuanchao 已提交
173
        console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup promise succeeded. result: ' + JSON.stringify(res));
W
wyuanchao 已提交
174
    }).catch( err => {
W
wyuanchao 已提交
175
        console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup promise failed. because: ' + err.code);
W
wyuanchao 已提交
176 177 178
    });

    // 异步方法callback方式
W
wyuanchao 已提交
179
    stats.queryAppUsagePriorityGroup((err, res) => {
W
wyuanchao 已提交
180
        if (err) {
W
wyuanchao 已提交
181
            console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup callback failed. because: ' + err.code);
W
wyuanchao 已提交
182 183
        } else {
            console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup callback succeeded. result: ' + JSON.stringify(res));
W
wyuanchao 已提交
184 185
        }
    });
W
wyuanchao 已提交
186 187
    ```

W
wyuanchao 已提交
188
7. 判断指定Bundle Name的应用当前是否是空闲状态,config.json中不需要配置权限。
W
wyuanchao 已提交
189 190

    ```js
W
wyuanchao 已提交
191
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
192 193 194

    // 异步方法promise方式
    stats.isIdleState("com.ohos.camera").then( res => {
W
wyuanchao 已提交
195
        console.log('BUNDLE_ACTIVE isIdleState promise succeeded, result: ' + JSON.stringify(res));
W
wyuanchao 已提交
196
    }).catch( err => {
W
wyuanchao 已提交
197
        console.log('BUNDLE_ACTIVE isIdleState promise failed, because: ' + err.code);
W
wyuanchao 已提交
198 199 200
    });

    // 异步方法callback方式
W
wyuanchao 已提交
201
    stats.isIdleState("com.ohos.camera", (err, res) => {
W
wyuanchao 已提交
202
        if (err) {
W
wyuanchao 已提交
203
            console.log('BUNDLE_ACTIVE isIdleState callback failed, because: ' + err.code);
W
wyuanchao 已提交
204 205
        } else {
            console.log('BUNDLE_ACTIVE isIdleState callback succeeded, result: ' + JSON.stringify(res));
W
wyuanchao 已提交
206 207
        }
    });
H
houdisheng 已提交
208 209
    ```

H
houdisheng 已提交
210
8. 查询FA使用记录。返回数量最大不超过maxNum设置的值,若不传入maxNum参数,则默认maxNum为1000。config.json中需要配置权限:ohos.permission.BUNDLE_ACTIVE_INFO。
H
houdisheng 已提交
211 212 213 214 215

    ```js
    import stats from '@ohos.bundleState'

    // 异步方法promise方式
H
houdisheng 已提交
216 217
    stats.getRecentlyUsedModules(this.maxNum).then( res => {
        console.log('BUNDLE_ACTIVE getRecentlyUsedModules promise succeeded');
H
houdisheng 已提交
218
        for (let i = 0; i < res.length; i++) {
H
houdisheng 已提交
219 220
            console.log('BUNDLE_ACTIVE getRecentlyUsedModules promise number : ' + (i + 1));
            console.log('BUNDLE_ACTIVE getRecentlyUsedModules promise result ' + JSON.stringify(res[i]));
H
houdisheng 已提交
221 222
        }
    }).catch( err=> {
H
houdisheng 已提交
223
        console.log('BUNDLE_ACTIVE getRecentlyUsedModules promise failed, because: ' + err.code);
H
houdisheng 已提交
224 225
    });

H
houdisheng 已提交
226 227 228 229 230 231 232 233 234 235 236
    // 无参数异步方法promise方式
    stats.getRecentlyUsedModules().then( res => {
        console.log('BUNDLE_ACTIVE getRecentlyUsedModules promise succeeded');
        for (let i = 0; i < res.length; i++) {
            console.log('BUNDLE_ACTIVE getRecentlyUsedModules promise number : ' + (i + 1));
            console.log('BUNDLE_ACTIVE getRecentlyUsedModules promise result ' + JSON.stringify(res[i]));
        }
    }).catch( err=> {
        console.log('BUNDLE_ACTIVE getRecentlyUsedModules promise failed, because: ' + err.code);
    });

H
houdisheng 已提交
237
    // 异步方法callback方式
H
houdisheng 已提交
238
    stats.getRecentlyUsedModules(this.maxNum,(err, res) => {
H
houdisheng 已提交
239
        if(err) {
H
houdisheng 已提交
240
            console.log('BUNDLE_ACTIVE getRecentlyUsedModules callback failed, because: ' + err.code);
H
houdisheng 已提交
241
        } else {
H
houdisheng 已提交
242
            console.log('BUNDLE_ACTIVE getRecentlyUsedModules callback succeeded.');
H
houdisheng 已提交
243
                for (let i = 0; i < res.length; i++) {
H
houdisheng 已提交
244 245
                    console.log('BUNDLE_ACTIVE getRecentlyUsedModules callback number : ' + (i + 1));
                    console.log('BUNDLE_ACTIVE getRecentlyUsedModules callback result ' + JSON.stringify(res[i]));
H
houdisheng 已提交
246 247 248
                }
            }
    });
H
houdisheng 已提交
249 250 251 252 253 254 255 256 257 258 259 260 261

    // 无参数异步方法callback方式
    stats.getRecentlyUsedModules((err, res) => {
        if(err) {
            console.log('BUNDLE_ACTIVE getRecentlyUsedModules callback failed, because: ' + err.code);
        } else {
            console.log('BUNDLE_ACTIVE getRecentlyUsedModules callback succeeded.');
                for (let i = 0; i < res.length; i++) {
                    console.log('BUNDLE_ACTIVE getRecentlyUsedModules callback number : ' + (i + 1));
                    console.log('BUNDLE_ACTIVE getRecentlyUsedModules callback result ' + JSON.stringify(res[i]));
                }
            }
    });
H
houdisheng 已提交
262 263
    ```