跳过主要内容
返回插件
@capgo/capacitor-compass
教程
由 github.com/Cap-go

compass

以每秒度数更新并处理权限的设备compass读取

指南

compass教程

使用@capgo/capacitor-compass

Capacitor Compass插件接口,用于读取设备compass方向

安装

bun add @capgo/capacitor-compass
bunx cap sync

此插件暴露的内容

  • getCurrentHeading - 获取当前compass方向(度数)。在iOS上,方向会在后台更新,返回最新值。在Android上,方向会在调用方法时使用加速计和磁力计传感器计算。未在Web上实现。
  • startListening - 开始监听compass方向变化的事件。这会启动compass传感器并发送'headingChange'事件。
  • stopListening - 停止监听compass方向变化的事件。这会停止compass传感器并停止发送事件。
  • checkPermissions - 检查访问compass数据的当前权限状态。 在iOS中,这检查位置权限状态。 在Android中,这始终返回'授权',因为没有权限要求。

示例用法

getCurrentHeading

获取当前compass方向(以度为单位)。 在iOS中,方向在后台更新,返回最新值。 在Android中,方向在调用方法时使用加速计和磁力计传感器计算。 未在Web中实现。

import { CapgoCompass } from '@capgo/capacitor-compass';

const { value } = await CapgoCompass.getCurrentHeading();
console.log('Compass heading:', value, 'degrees');

startListening

开始监听compass方向变化的事件。 这开始compass传感器并发出'headingChange'事件。

import { CapgoCompass } from '@capgo/capacitor-compass';

// With default throttling (100ms interval, 2° minimum change)
await CapgoCompass.startListening();

// With custom throttling for high-frequency updates
await CapgoCompass.startListening({
  minInterval: 50,      // 50ms between events
  minHeadingChange: 1.0 // 1° minimum change
});

CapgoCompass.addListener('headingChange', (event) => {
  console.log('Heading:', event.value);
});

stopListening

停止监听compass方向变化的事件。 这停止compass传感器并停止发出事件。

import { CapgoCompass } from '@capgo/capacitor-compass';

await CapgoCompass.stopListening();

checkPermissions

检查访问compass数据的当前权限状态。 在iOS中,这检查位置权限状态。 在Android中,这始终返回'授权',因为没有权限要求。

import { CapgoCompass } from '@capgo/capacitor-compass';

const status = await CapgoCompass.checkPermissions();
console.log('Compass permission:', status.compass);

全局参考