Skip to content
更新时间:

@ohos.stationary (设备状态感知框架)

设备状态感知框架提供设备状态感知能力,包括绝对静止和相对静止。

说明:

本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

本模块不支持x86模拟器。

导入模块

js
import stationary from '@ohos.stationary'

ActivityResponse

服务响应抽象接口。

系统能力:SystemCapability.Msdp.DeviceStatus.Stationary

属性

名称类型可读可写说明
stateActivityState设备状态变化返回值。

ActivityType

设备状态类型。

系统能力:SystemCapability.Msdp.DeviceStatus.Stationary

名称说明
still绝对静止。
relativeStill相对静止。

ActivityEvent

设备状态事件。

系统能力:SystemCapability.Msdp.DeviceStatus.Stationary

名称说明
ENTER1进入。
EXIT2退出。
ENTER_EXIT3进入和退出。

ActivityState

设备状态返回值。

系统能力:SystemCapability.Msdp.DeviceStatus.Stationary

名称说明
ENTER1进入。
EXIT2退出。

stationary.on('still' | 'relativeStill')

on(activity: ActivityType, event: ActivityEvent, reportLatencyNs: number, callback: Callback<ActivityResponse>): void

设备状态管理,订阅设备状态服务。

系统能力:SystemCapability.Msdp.DeviceStatus.Stationary

参数:

参数名类型必填说明
activityActivityType设备状态能力类型。
eventActivityEvent事件类型。
reportLatencyNsnumber报告延时。
callbackCallback<ActivityResponse>回调函数,接收上报状态变化事件。

示例:

js
let reportLatencyNs = 100;
stationary.on('still', stationary.ActivityEvent.ENTER, reportLatencyNs, (data) => {
    console.log('data='+ JSON.stringify(data));
})

stationary.once('still' | 'relativeStill')

once(activity: ActivityType, callback: Callback<ActivityResponse>): void

设备状态管理,查询设备状态。

系统能力:SystemCapability.Msdp.DeviceStatus.Stationary

参数:

参数名类型必填说明
activityActivityType设备状态能力类型。
callbackCallback<ActivityResponse>回调函数,接收上报状态变化事件。

示例:

js
stationary.once('still', (data) => {
    console.log("data="+ JSON.stringify(data));
})

stationary.off('still' | 'relativeStill')

off(activity: ActivityType, event: ActivityEvent, callback?: Callback<ActivityResponse>): void

设备状态管理,取消订阅设备状态服务。

系统能力:SystemCapability.Msdp.DeviceStatus.Stationary

参数:

参数名类型必填说明
activityActivityType设备状态能力类型。
eventActivityEvent事件类型。
callbackCallback:<ActivityResponse>回调函数,接收上报状态变化事件,如果没有传递callback参数或者传递的类型是undefined,会移除该进程下订阅该类型得所有callback。

示例:

js
stationary.off('still', stationary.ActivityEvent.ENTER);