@capacitor/motion
Motion API 用于追踪加速度计和设备方向(指南针航向等)
安装
npm install @capacitor/motion@latest-5
npx cap sync
权限
此插件目前使用 Web API 实现。大多数浏览器在使用此 API 前需要获取权限。要请求权限,请在用户发起操作(如按钮点击)时提示用户:
import { PluginListenerHandle } from '@capacitor/core';
import { Motion } from '@capacitor/motion';
let accelHandler: PluginListenerHandle;
myButton.addEventListener('click', async () => {
try {
await DeviceMotionEvent.requestPermission();
} catch (e) {
// 处理错误
return;
}
// 一旦用户批准,即可开始监听:
accelHandler = await Motion.addListener('accel', event => {
console.log('设备运动事件:', event);
});
});
// 停止加速度监听
const stopAcceleration = () => {
if (accelHandler) {
accelHandler.remove();
}
};
// 移除所有监听器
const removeListeners = () => {
Motion.removeAllListeners();
};
请查阅 DeviceMotionEvent API 来了解 'accel' 事件中提供的数据。
API
addListener('accel', ...)
addListener(eventName: 'accel', listenerFunc: AccelListener) => Promise<PluginListenerHandle> & PluginListenerHandle
添加加速度计数据监听器
| 参数 | 类型 |
|---|---|
eventName | 'accel' |
listenerFunc | |
返回值:
Promise<PluginListenerHandle> & PluginListenerHandle
自: 1.0.0
addListener('orientation', ...)
addListener(eventName: 'orientation', listenerFunc: OrientationListener) => Promise<PluginListenerHandle> & PluginListenerHandle
添加设备方向变化监听器(指南针航向等)
| 参数 | 类型 |
|---|---|
eventName | 'orientation' |
listenerFunc | |
返回值:
Promise<PluginListenerHandle> & PluginListenerHandle
自: 1.0.0
removeAllListeners()
removeAllListeners() => Promise<void>
移除附加到此插件的所有监听器。
自: 1.0.0
接口
PluginListenerHandle
| 属性 | 类型 |
|---|---|
remove | () => Promise<void> |
AccelListenerEvent
| 属性 | 类型 | 描述 | 自 |
|---|---|---|---|
acceleration | | 一个对象,提供设备在三个轴 X、Y 和 Z 上的加速度。Acceleration 以 m/s(米/秒)表示 | 1.0.0 |
accelerationIncludingGravity | | 一个对象,提供设备在三个轴 X、Y 和 Z 上包含重力影响的加速度。Acceleration 以 m/s(米/秒)表示 | 1.0.0 |
rotationRate | | 一个对象,提供设备在三个方向轴 alpha、beta 和 gamma 上的方向变化率。旋转速率以度每秒表示。 | 1.0.0 |
interval | number | 一个数字,表示从设备获取数据的时间间隔,单位为毫秒。 | 1.0.0 |
Acceleration
| 属性 | 类型 | 描述 | 自 |
|---|---|---|---|
x | number | 沿 X 轴的加速度量。 | 1.0.0 |
y | number |