device-usage-statistics-dev-guide.md 22.6 KB
Newer Older
1
# 设备使用信息统计
W
wyuanchao 已提交
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
| 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 已提交
22 23
| function queryAppUsagePriorityGroup(callback: AsyncCallback<number>): void | 查询当前应用的使用优先级群组。callback形式。 |
| function queryAppUsagePriorityGroup(): Promise<number>; | 查询当前应用的使用优先级群组。promise形式。 |
W
wyuanchao 已提交
24
| function isIdleState(bundleName: string, callback: AsyncCallback<boolean>): void | 判断指定Bundle Name的应用当前是否是空闲状态。 |
25 26
| function getRecentlyUsedModules(callback: AsyncCallback<BundleActiveModuleInfo>): void | 查询FA使用记录,返回不超过1000条FA使用记录。 |
| function getRecentlyUsedModules(maxNum : number, callback: AsyncCallback<BundleActiveModuleInfo>): void | 根据maxNum,查询FA使用记录,返回不超过maxNum条FA使用记录,若不填写maxNum参数,则默认maxNum值为1000。 |
W
wyuanchao 已提交
27 28
| function queryAppNotificationNumber(begin: number, end: number, callback: AsyncCallback<Array<BundleActiveEventState>>): void | 通过指定起始和结束时间查询所有应用的通知次数。 |
| function queryBundleActiveEventStates(begin: number, end: number, callback: AsyncCallback<Array<BundleActiveEventState>>): void | 通过指定起始和结束时间查询系统事件(休眠、唤醒、解锁、锁屏)统计信息。 |
29
| function queryAppUsagePriorityGroup(bundleName : string, callback: AsyncCallback<number>): void | 查询当前调用者应用或者指定应用的使用优先级群组。callback形式。 |
Y
yupeng74@huawei.com 已提交
30 31 32
| function queryAppUsagePriorityGroup(bundleName? : string): Promise<number>; | 查询当前调用者应用或者指定应用的使用优先级群组。promise形式。 |
| function setBundleGroup(bundleName : string, newGroup: GroupType, callback: AsyncCallback>boolean>): void | 给应用名是bundleName的应用分组设置成newGroup,返回设置结果是否成功,以callback形式返回。 |
| function setBundleGroup(bundleName : string, newGroup : GroupType): Promise>boolean>; | 给应用名是bundleName的应用分组设置成newGroup,返回设置结果是否成功,以promise形式返回。 |
33 34
| function registerGroupCallBack(groupCallback: Callback>BundleActiveGroupCallbackInfo>, callback: AsyncCallback>boolean>): void | 注册应用分组变化监听回调,返回注册是否成功,当应用分组发生变化时,会给所有已注册的监听者返回回调信息,以callback形式返回。 |
| function registerGroupCallBack(groupCallback: Callback>BundleActiveGroupCallbackInfo>): Promise>boolean>; | 注册应用分组变化监听回调,返回注册是否成功,当应用分组发生变化时,会给所有已注册的监听者返回回调信息,以promise形式返回。 |
Y
yupeng74@huawei.com 已提交
35 36
| function unRegisterGroupCallBack(callback: AsyncCallback>boolean>): void | 解除应用分组监听回调,以callback形式返回。 |
| function unRegisterGroupCallBack(): Promise>boolean>; | 解除应用分组监听回调,以promise形式返回。 |
W
wyuanchao 已提交
37 38 39

## 开发步骤

W
wyuanchao 已提交
40
1. 在config.json文件中配置设备使用信息统计权限。
W
wyuanchao 已提交
41 42 43 44 45 46 47

    ```json
    "module": {
        "package": "com.example.deviceUsageStatistics",
        ...,
        "reqPermissions": [
            {
48
                "name": "ohos.permission.BUNDLE_ACTIVE_INFO"
W
wyuanchao 已提交
49 50 51 52 53
            }
        ]
    }
    ```

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

    ```js
W
wyuanchao 已提交
57
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
58 59

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

    // 异步方法callback方式
W
wyuanchao 已提交
71
    stats.queryBundleActiveStates(0, 20000000000000, (err, res) => {
W
wyuanchao 已提交
72 73 74
        if (err) {
            console.log('BUNDLE_ACTIVE queryBundleActiveStates callback failed, because: ' + err.code);
        } else {
W
wyuanchao 已提交
75 76 77 78
            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 已提交
79
            }
W
wyuanchao 已提交
80 81
        }
    });
W
wyuanchao 已提交
82 83
    ```

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

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

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

    // 异步方法callback方式
W
wyuanchao 已提交
103
    stats.queryBundleStateInfos(0, 20000000000000, (err, res) => {
W
wyuanchao 已提交
104 105 106
        if (err) {
            console.log('BUNDLE_ACTIVE queryBundleStateInfos callback failed, because: ' + err.code);
        } else {
W
wyuanchao 已提交
107 108 109 110 111 112
            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 已提交
113
            }
W
wyuanchao 已提交
114 115
        }
    });
W
wyuanchao 已提交
116 117
    ```

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

    ```js
W
wyuanchao 已提交
121
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
122 123

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

    // 异步方法callback方式
W
wyuanchao 已提交
135
    stats.queryCurrentBundleActiveStates(0, 20000000000000, (err, res) => {
W
wyuanchao 已提交
136 137 138
        if (err) {
            console.log('BUNDLE_ACTIVE queryCurrentBundleActiveStates callback failed, because: ' + err.code);
        } else {
W
wyuanchao 已提交
139 140 141 142
            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 已提交
143
            }
W
wyuanchao 已提交
144 145
        }
    });
W
wyuanchao 已提交
146 147
    ```

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

    ```js
W
wyuanchao 已提交
151
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
152 153

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

    // 异步方法callback方式
W
wyuanchao 已提交
165
    stats.queryBundleStateInfoByInterval(0, 0, 20000000000000, (err, res) => {
W
wyuanchao 已提交
166 167 168
        if (err) {
            console.log('BUNDLE_ACTIVE queryBundleStateInfoByInterval callback failed, because: ' + err.code);
        } else {
W
wyuanchao 已提交
169 170 171 172
            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 已提交
173
            }
W
wyuanchao 已提交
174 175
        }
    });
W
wyuanchao 已提交
176 177
    ```

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

    ```js
W
wyuanchao 已提交
181
    import stats from '@ohos.bundleState'
182

Y
yupeng74@huawei.com 已提交
183
    // promise方式
184
    stats.queryAppUsagePriorityGroup().then(res => {
W
wyuanchao 已提交
185
        console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup promise succeeded. result: ' + JSON.stringify(res));
186
    }).catch(err => {
W
wyuanchao 已提交
187
        console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup promise failed. because: ' + err.code);
W
wyuanchao 已提交
188
    });
189

Y
yupeng74@huawei.com 已提交
190
    // callback方式
W
wyuanchao 已提交
191
    stats.queryAppUsagePriorityGroup((err, res) => {
W
wyuanchao 已提交
192
        if (err) {
W
wyuanchao 已提交
193
            console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup callback failed. because: ' + err.code);
W
wyuanchao 已提交
194 195
        } else {
            console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup callback succeeded. result: ' + JSON.stringify(res));
W
wyuanchao 已提交
196 197
        }
    });
W
wyuanchao 已提交
198
    ```
199

W
wyuanchao 已提交
200
7. 判断指定Bundle Name的应用当前是否是空闲状态,config.json中不需要配置权限,三方应用只能查询自身的空闲状态。
W
wyuanchao 已提交
201 202

    ```js
W
wyuanchao 已提交
203
    import stats from '@ohos.bundleState'
W
wyuanchao 已提交
204 205

    // 异步方法promise方式
206
    stats.isIdleState("com.ohos.camera").then(res => {
W
wyuanchao 已提交
207
        console.log('BUNDLE_ACTIVE isIdleState promise succeeded, result: ' + JSON.stringify(res));
208
    }).catch(err => {
W
wyuanchao 已提交
209
        console.log('BUNDLE_ACTIVE isIdleState promise failed, because: ' + err.code);
W
wyuanchao 已提交
210 211 212
    });

    // 异步方法callback方式
W
wyuanchao 已提交
213
    stats.isIdleState("com.ohos.camera", (err, res) => {
W
wyuanchao 已提交
214
        if (err) {
W
wyuanchao 已提交
215
            console.log('BUNDLE_ACTIVE isIdleState callback failed, because: ' + err.code);
W
wyuanchao 已提交
216 217
        } else {
            console.log('BUNDLE_ACTIVE isIdleState callback succeeded, result: ' + JSON.stringify(res));
W
wyuanchao 已提交
218 219
        }
    });
H
houdisheng 已提交
220 221
    ```

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

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

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

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

H
houdisheng 已提交
262
    // 无maNum参数异步方法callback方式
H
houdisheng 已提交
263
    stats.getRecentlyUsedModules((err, res) => {
264
        if (err) {
H
houdisheng 已提交
265 266 267 268 269 270 271 272 273
            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 已提交
274 275
    ```

W
wyuanchao 已提交
276 277 278 279 280 281
9. 通过指定起始和结束时间查询所有应用的通知次数,config.json中需要配置权限:ohos.permission.BUNDLE_ACTIVE_INFO。

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

    // 异步方法promise方式
282
    stats.queryAppNotificationNumber(0, 20000000000000).then(res => {
W
wyuanchao 已提交
283 284
        console.log('BUNDLE_ACTIVE queryAppNotificationNumber promise success.');
        console.log('BUNDLE_ACTIVE queryAppNotificationNumber promise result ' + JSON.stringify(res));
285
    }).catch(err => {
W
wyuanchao 已提交
286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303
        console.log('BUNDLE_ACTIVE queryAppNotificationNumber promise failed, because: ' + err.code);
    });

    // 异步方法callback方式
    stats.queryAppNotificationNumber(0, 20000000000000, (err, res) => {
        if (err) {
            console.log('BUNDLE_ACTIVE queryAppNotificationNumber callback failed, because: ' + err.code);
        } else {
            console.log('BUNDLE_ACTIVE queryAppNotificationNumber callback success.');
            console.log('BUNDLE_ACTIVE queryAppNotificationNumber callback result ' + JSON.stringify(res));
        }
    });
    ```

10. 通过指定起始和结束时间查询系统事件(休眠、唤醒、解锁、锁屏)统计信息,config.json中需要配置权限:ohos.permission.BUNDLE_ACTIVE_INFO。

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

W
wyuanchao 已提交
305
    // 异步方法promise方式
306
    stats.queryBundleActiveEventStates(0, 20000000000000).then(res => {
W
wyuanchao 已提交
307 308
        console.log('BUNDLE_ACTIVE queryBundleActiveEventStates promise success.');
        console.log('BUNDLE_ACTIVE queryBundleActiveEventStates promise result ' + JSON.stringify(res));
309
    }).catch(err => {
W
wyuanchao 已提交
310 311
        console.log('BUNDLE_ACTIVE queryBundleActiveEventStates promise failed, because: ' + err.code);
    });
312

W
wyuanchao 已提交
313 314 315 316 317 318 319 320 321
    // 异步方法callback方式
    stats.queryBundleActiveEventStates(0, 20000000000000, (err, res) => {
        if (err) {
            console.log('BUNDLE_ACTIVE queryBundleActiveEventStates callback failed, because: ' + err.code);
        } else {
            console.log('BUNDLE_ACTIVE queryBundleActiveEventStates callback success.');
            console.log('BUNDLE_ACTIVE queryBundleActiveEventStates callback result ' + JSON.stringify(res));
        }
    });
Y
yupeng74@huawei.com 已提交
322 323
    ```

Y
yupeng74@huawei.com 已提交
324 325 326 327
11. 查询(无参)当前调用者应用的使用优先级群组,config.json中不需要配置权限。查询(有参)指定应用的使用优先级群组,config.json中需要配置权限:ohos.permission.BUNDLE_ACTIVE_INFO。

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

329
     // 无bundleName异步方法promise方式
330
     stats.queryAppUsagePriorityGroup().then(res => {
Y
yupeng74@huawei.com 已提交
331
         console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup promise succeeded. result: ' + JSON.stringify(res));
332
     }).catch(err => {
Y
yupeng74@huawei.com 已提交
333 334
         console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup promise failed. because: ' + err.code);
     });
335

336
     // 无bundleName异步方法callback方式
Y
yupeng74@huawei.com 已提交
337 338 339 340 341 342 343
     stats.queryAppUsagePriorityGroup((err, res) => {
         if (err) {
             console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup callback failed. because: ' + err.code);
         } else {
             console.log('BUNDLE_ACTIVE queryAppUsagePriorityGroup callback succeeded. result: ' + JSON.stringify(res));
         }
     });
344 345 346
    let bundleName = "com.ohos.camera";
     // 有bundleName异步promise方式
     stats.queryAppUsagePriorityGroup(bundleName).then(res => {
Y
yupeng74@huawei.com 已提交
347
         console.log('BUNDLE_ACTIVE QueryPackageGroup promise succeeded. result: ' + JSON.stringify(res));
348
     }).catch(err => {
Y
yupeng74@huawei.com 已提交
349 350
         console.log('BUNDLE_ACTIVE QueryPackageGroup promise failed. because: ' + err.code);
     });
351

352 353
     // 有bundleName异步方法callback方式
     stats.queryAppUsagePriorityGroup(bundleName, (err, res) => {
354
         if (err) {
Y
yupeng74@huawei.com 已提交
355 356 357 358 359 360 361
             console.log('BUNDLE_ACTIVE QueryPackageGroup callback failed. because: ' + err.code);
         } else {
             console.log('BUNDLE_ACTIVE QueryPackageGroup callback succeeded. result: ' + JSON.stringify(res));
         }
     });
     ```

Y
yupeng74@huawei.com 已提交
362 363 364 365
11. 给应用名是bundleName的应用分组设置成newGroup,返回设置结果是否成功

    ```javascript
    import stats from '@ohos.bundleState'
366

367
    // 异步方法promise
368
    stats.setBundleGroup(this.bundleName, this.newGroup).then(() => {
Y
yupeng74@huawei.com 已提交
369
        console.log('BUNDLE_ACTIVE SetBundleGroup promise succeeded.');
Y
yupeng74@huawei.com 已提交
370 371 372
    }).catch( err => {
        console.log('BUNDLE_ACTIVE SetBundleGroup promise failed. because: ' + err.code);
    });
373
    // 异步方法callback
Y
yupeng74@huawei.com 已提交
374
    stats.setBundleGroup(this.bundleName, this.newGroup, (err) => {
375
        if (err) {
Y
yupeng74@huawei.com 已提交
376 377
            console.log('BUNDLE_ACTIVE SetBundleGroup callback failed. because: ' + err.code);
        } else {
Y
yupeng74@huawei.com 已提交
378
            console.log('BUNDLE_ACTIVE SetBundleGroup callback succeeded.');
Y
yupeng74@huawei.com 已提交
379 380 381 382 383 384 385 386
        }
    });
    ```

12. 注册应用分组变化监听回调,返回注册是否成功,当应用分组发生变化时,会给所有已注册的监听者返回回调信息

    ```javascript
    import stats from '@ohos.bundleState'
387

388
    // 异步方法promise形式
389
    let onBundleGroupChanged = (err,res) => {
Y
yupeng74@huawei.com 已提交
390 391 392 393 394 395 396
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack callback success.');
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result oldGroup is : ' + res.oldGroup);
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result newGroup is : ' + res.newGroup);
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result changeReason is : ' + res.newGroup);
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result userId is : ' + res.userId);
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result bundleName is : ' + res.bundleName);
    };
397
    stats.registerGroupCallBack(onBundleGroupChanged).then(() => {
Y
yupeng74@huawei.com 已提交
398
        console.log('BUNDLE_ACTIVE RegisterGroupCallBack promise succeeded.');
399
    }).catch(err => {
Y
yupeng74@huawei.com 已提交
400 401
        console.log('BUNDLE_ACTIVE RegisterGroupCallBack promise failed. because: ' + err.code);
    });
402
    // 异步方法callback形式
403
    let onBundleGroupChanged = (err,res) => {
Y
yupeng74@huawei.com 已提交
404 405 406 407 408 409 410
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack callback success.');
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result‘s oldGroup is : ' + res.oldGroup);
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result‘s newGroup is : ' + res.newGroup);
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result‘s changeReason is : ' + res.newGroup);
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result‘s userId is : ' + res.userId);
        console.log('BUNDLE_ACTIVE onBundleGroupChanged RegisterGroupCallBack result‘s bundleName is : ' + res.bundleName);
    };
411 412
    stats.registerGroupCallBack(onBundleGroupChanged, (err) => {
        if (err) {
Y
yupeng74@huawei.com 已提交
413 414 415 416 417 418
            console.log('BUNDLE_ACTIVE RegisterGroupCallBack callback failed, because: ' + err.code);
        } else {
            console.log('BUNDLE_ACTIVE RegisterGroupCallBack callback success.');
        }
    });
    ```
419

Y
yupeng74@huawei.com 已提交
420 421 422 423
13. 解除应用分组监听回调

    ```javascript
    import stats from '@ohos.bundleState'
424

425
    // promise
426
    stats.unRegisterGroupCallBack().then(() => {
Y
yupeng74@huawei.com 已提交
427
        console.log('BUNDLE_ACTIVE UnRegisterGroupCallBack promise succeeded.');
428
    }).catch(err => {
Y
yupeng74@huawei.com 已提交
429 430
        console.log('BUNDLE_ACTIVE UnRegisterGroupCallBack promise failed. because: ' + err.code);
    });
431
    // callback
432 433
    stats.unRegisterGroupCallBack((err) => {
        if (err) {
Y
yupeng74@huawei.com 已提交
434 435 436 437 438 439
            console.log('BUNDLE_ACTIVE UnRegisterGroupCallBack callback failed, because: ' + err.code);
        } else {
            console.log('BUNDLE_ACTIVE UnRegisterGroupCallBack callback success.');
        }
    });
    ```
440 441
## 相关实例
针对设备使用信息统计,有以下相关实例可供参考:
442
- [`DeviceUsageStatistics`:设备使用信息统计(eTS)(API8)(Full SDK)](https://gitee.com/openharmony/applications_app_samples/tree/master/device/DeviceUsageStatistics)
Y
yupeng74@huawei.com 已提交
443