Mulai Berjalan
Salin prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-compass`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/compass/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
__CAPGO_KEEP_0__
Bagian berjudul “Install”bun add @capgo/capacitor-compassbunx cap syncimport { CapgoCompass } from '@capgo/capacitor-compass';API Ringkasan
Bagian berjudul “API Ringkasan”getCurrentHeading
Bagian berjudul “getCurrentHeading”Dapatkan arah kompas saat ini dalam derajat. Di iOS, arah kompas diperbarui di latar belakang, dan nilai terbaru dikembalikan. Di Android, arah kompas dihitung ketika metode dipanggil menggunakan sensor accelerometer dan magnetometer. Belum diimplementasikan di Web.
import { CapgoCompass } from '@capgo/capacitor-compass';
const { value } = await CapgoCompass.getCurrentHeading();console.log('Compass heading:', value, 'degrees');startListening
Bagian berjudul “startListening”Mulai mendengarkan perubahan arah kompas melalui event. Fungsi ini memulai sensor kompas dan mengirimkan event ‘headingChange’.
import { CapgoCompass } from '@capgo/capacitor-compass';
// With default throttling (100ms interval, 2° minimum change)await CapgoCompass.startListening();
// With custom throttling for high-frequency updatesawait CapgoCompass.startListening({ minInterval: 50, // 50ms between events minHeadingChange: 1.0 // 1° minimum change});
CapgoCompass.addListener('headingChange', (event) => { console.log('Heading:', event.value);});stopListening
Bagian berjudul “stopListening”Berhenti mendengarkan perubahan arah kompas. Fungsi ini menghentikan sensor kompas dan menghentikan pengiriman event.
import { CapgoCompass } from '@capgo/capacitor-compass';
await CapgoCompass.stopListening();checkPermissions
Bagian berjudul “checkPermissions”Periksa status izin saat ini untuk mengakses data kompas. Pada iOS, fungsi ini memeriksa status izin lokasi. Pada Android, fungsi ini selalu mengembalikan ‘granted’ karena tidak ada izin yang diperlukan.
import { CapgoCompass } from '@capgo/capacitor-compass';
const status = await CapgoCompass.checkPermissions();console.log('Compass permission:', status.compass);requestPermissions
Bagian berjudul “requestPermissions”Minta izin untuk mengakses data kompas. Pada iOS, fungsi ini meminta izin lokasi (diperlukan untuk data arah). Pada Android, fungsi ini segera diselesaikan karena tidak ada izin yang diperlukan.
import { CapgoCompass } from '@capgo/capacitor-compass';
const status = await CapgoCompass.requestPermissions();if (status.compass === 'granted') { // Can now use compass}watchAccuracy
Bagian berjudul “watchAccuracy”Mulai memantau akurasi kompas. Di Android, ini memantau akurasi magnetometer dan mengeluarkan peristiwa perubahan akurasi. Para pengembang dapat mendengarkan peristiwa ini dan menerapkan UI sendiri untuk permintaan kalibrasi. Di iOS dan Web, metode ini tidak melakukan apa-apa karena memantau akurasi kompas tidak tersedia.
import { CapgoCompass } from '@capgo/capacitor-compass';
// Start monitoring accuracyawait CapgoCompass.watchAccuracy();
// Listen for accuracy changes and implement custom UICapgoCompass.addListener('accuracyChange', (event) => { console.log('Accuracy changed to:', event.accuracy); if (event.accuracy < CompassAccuracy.MEDIUM) { // Show your custom calibration UI }});unwatchAccuracy
Bagian berjudul “unwatchAccuracy”Hentikan memantau akurasi kompas. Ini menghentikan memantau akurasi.
import { CapgoCompass } from '@capgo/capacitor-compass';
await CapgoCompass.unwatchAccuracy();getAccuracy
Bagian berjudul “getAccuracy”Ambil akurasi kompas saat ini. Di Android, mengembalikan akurasi sensor magnetometer saat ini. Di iOS dan Web, selalu mengembalikan CompassAccuracy.UNKNOWN karena memantau akurasi kompas tidak tersedia.
import { CapgoCompass } from '@capgo/capacitor-compass';
const { accuracy } = await CapgoCompass.getAccuracy();if (accuracy < CompassAccuracy.MEDIUM) { console.log('Compass needs calibration');}Referensi Tipe
Bagian berjudul “Referensi Tipe”CompassHeading
Bagian berjudul “CompassHeading”Hasil yang berisi nilai arah kompas.
export interface CompassHeading { /** Compass heading in degrees (0-360) */ value: number;}ListeningOptions
Bagian berjudul “ListeningOptions”Pilihan untuk mengonfigurasi perilaku mendengarkan kompas.
export interface ListeningOptions { /** * Minimum interval between heading change events in milliseconds. * Lower values = more frequent updates but higher CPU/battery usage. * * @default 100 * @since 8.1.4 */ minInterval?: number;
/** * Minimum heading change in degrees required to trigger an event. * Lower values = more sensitive but more events. * Handles wraparound (e.g., 359° to 1° = 2° change). * * @default 2.0 * @since 8.1.4 */ minHeadingChange?: number;}HeadingChangeEvent
Bagian berjudul “HeadingChangeEvent”Data acara perubahan arah.
export interface HeadingChangeEvent { /** Compass heading in degrees (0-360) */ value: number;}AccuracyChangeEvent
Bagian berjudul “AccuracyChangeEvent”Data acara perubahan akurasi.
export interface AccuracyChangeEvent { /** Current accuracy level of the compass */ accuracy: CompassAccuracy;}PermissionStatus
Bagian berjudul “PermissionStatus”Status izin untuk plugin kompas.
export interface PermissionStatus { /** * Permission state for accessing compass/location data. * On iOS, this requires location permission to access heading. * On Android, no special permissions are required for compass sensors. * * @since 7.0.0 */ compass: PermissionState;}CompassAccuracy
Bagian berjudul “Akurasi Kompas”Konstanta tingkat akurasi kompas.
export enum CompassAccuracy { /** High accuracy - approximates to less than 5 degrees of error */ HIGH = 3, /** Medium accuracy - approximates to less than 10 degrees of error */ MEDIUM = 2, /** Low accuracy - approximates to less than 15 degrees of error */ LOW = 1, /** Unreliable accuracy - approximates to more than 15 degrees of error */ UNRELIABLE = 0, /** Unknown accuracy value */ UNKNOWN = -1,}PermissionState
Bagian berjudul “Status Izin”Status izin akses kompas.
export type PermissionState = 'prompt' | 'prompt-with-rationale' | 'granted' | 'denied';Sumber Kebenaran
Bagian berjudul “Sumber Kebenaran”Halaman ini dihasilkan dari plugin’s src/definitions.ts. Re-run sinkronisasi ketika publik API berubah di atas.
Lanjutkan dari Getting Started
Bagian berjudul “Teruskan dari Getting Started”Jika Anda menggunakan Pembukaan untuk merencanakan dashboard dan API operasi, hubungkannya dengan Menggunakan @capgo/capacitor-compass untuk kemampuan asli dalam Menggunakan @capgo/capacitor-compass, Ringkasan API untuk detail implementasi dalam Ringkasan API, Pendahuluan untuk detail implementasi dalam Pendahuluan, Kunci API untuk detail implementasi dalam Kunci API, Perangkat untuk detail implementasi di Perangkat.