获取用户动作开发指导
场景介绍
当应用需要获取用户动作时,可以调用motion模块,例如判断用户当前是用左手还是右手操作设备屏幕。
详细的接口介绍请参考@ohos.multimodalAwareness.motion (动作感知能力)。
从API version 15开始,支持获取操作手状态。从API version 20开始,支持获取握持手状态。
获取操作手状态开发指导
接口说明
| 接口名 | 描述 |
|---|---|
| on(type:'operatingHandChanged',callback:Callback<OperatingHandStatus>):void; | 订阅操作手感知,操作手结果通过callback返回。 |
| off(type: 'operatingHandChanged', callback?: Callback<OperatingHandStatus>): void; | 取消订阅操作手感知。 |
| getRecentOperatingHandStatus(): OperatingHandStatus; | 获取最新的操作手状态。 |
需要权限
使用motion模块获取用户操作手时,需要权限:ohos.permission.ACTIVITY_MOTION 或 ohos.permission.DETECT_GESTURE,具体申请方式请参考声明权限。
"requestPermissions":[
{
"name" : "ohos.permission.ACTIVITY_MOTION"
},
{
"name" : "ohos.permission.DETECT_GESTURE"
}
]
约束与限制
- 此功能如果设备不支持,将返回801错误码。
- 指关节操作不属于使用手操作场景。
- 窗口旋转场景,多指同时操作场景不支持。
- 能力有效范围:不包含距离屏幕边缘8mm内区域。
- 结果上报条件:首次订阅或切换操作手后,连续点数次触发。
- 触控响应说明:屏幕四周边缘8mm范围内不支持触控响应。
开发步骤
-
导入模块。
import { motion } from '@kit.MultimodalAwarenessKit';import { BusinessError } from '@kit.BasicServicesKit'; -
定义回调函数接收操作手结果
let callback:Callback<motion.OperatingHandStatus> = (data:motion.OperatingHandStatus) => {console.info('callback succeeded' + data);}; -
订阅操作手感知
try {motion.on('operatingHandChanged', callback);console.info("on succeeded");} catch (err) {let error = err as BusinessError;console.error("Failed on and err code is " + error.code);} -
取消订阅操作手感知
try {motion.off('operatingHandChanged');console.info("off succeeded");} catch (err) {let error = err as BusinessError;console.error("Failed off and err code is " + error.code);} -
获取最新操作手状态
try {let data:motion.OperatingHandStatus = motion.getRecentOperatingHandStatus();console.info('get succeeded' + data);} catch (err) {let error = err as BusinessError;console.error("Failed get and err code is " + error.code);}
获取握持手状态开发指导
接口说明
| 接口名 | 描述 |
|---|---|
| on(type:'holdingHandChanged',callback:Callback<HoldingHandStatus>): void; | 订阅握持手感知,感知结果通过callback返回。 |
| off(type: 'holdingHandChanged', callback?: Callback<HoldingHandStatus>): void; | 取消订阅握持手感知。 |
需要权限
使用motion模块获取用户握持手时,需要权限: ohos.permission.DETECT_GESTURE,具体申请方式请参考声明权限。
"requestPermissions":[
{
"name" : "ohos.permission.DETECT_GESTURE"
}
]
约束与限制
- 此功能当前支持部分机型,若设置菜单中存在“智感握姿”开关(可在“设置-系统”中查看),则表明该设备支持此功能,若无此开关,将返回801错误码。
- 设备屏幕需处于亮屏且解锁状态。
- 设备保护壳(若有)厚度不得超过3毫米。
- 需以五指自然握持设备,同时掌心区域接触设备(或拇指外的四指及掌心区域接触)。
- 握持时确保每根接触手指的接触面积尽可能大(理想情况下不低于30mm²)。
- 佩戴手套会显著降低识别准确率。
- 竖屏握持时,摄像头需朝上。
- 支持横屏握持,但需要注意:应用横屏时竖屏握持即握持设备长边,应用竖屏时横屏握持即握持设备短边,均属异常姿态,无法保证识别成功。
- 握持时屏幕需朝向握持人。
- 握持时不得同时接触其他物体(如桌面、其他身体部位等)。
- 未握持的识别依赖设备状态,设备非静止时无法保证识别成功。
开发步骤
-
导入模块。
import { motion } from '@kit.MultimodalAwarenessKit';import { BusinessError } from '@kit.BasicServicesKit'; -
定义回调函数接收握持手结果
let callback:Callback<motion.HoldingHandStatus> = (data:motion.HoldingHandStatus) => {console.info('callback succeeded' + data);}; -
订阅握持手感知
try {motion.on('holdingHandChanged', callback);console.info("on succeeded");} catch (err) {let error = err as BusinessError;console.error("Failed on and err code is " + error.code);} -
取消订阅握持手感知
try {motion.off('holdingHandChanged');console.info("off succeeded");} catch (err) {let error = err as BusinessError;console.error("Failed off and err code is " + error.code);}