Vai alla sezione principale
Torna ai plugin
@capgo/capacitor-background-geolocation
Tutorial
@capgo/capacitor-background-geolocation

Geolocalizzazione in background

Rilevamento della posizione in background preciso con geofencing nativo per iOS e Android e webhook di transizione

Guida

Tutorial sulla geolocalizzazione di background

Utilizza @capgo/background-geolocation

Geolocalizzazione di background precisa e geofencing nativo per le app Capacitor su iOS e Android. Utilizzalo per streamare aggiornamenti di posizione precisi, monitorare regioni circolari e inviare transizioni di ingresso/uscita di geofence al JavaScript o al tuo backend.

Installa

bun add @capgo/background-geolocation
bunx cap sync

Cosa questo plugin espone

  • start - Invia aggiornamenti di posizione di foreground o background precisi.
  • stop - Ferma la tracciatura di posizione attiva.
  • openSettings - Apri le impostazioni native quando gli utenti devono risolvere i permessi di posizione.
  • setPlannedRoute - Riproduci un suono nativo quando l'utente lascia una rotta pianificata.
  • setupGeofencing - Configura le impostazioni di geofencing nativo e l'invio facoltativo di webhook di transizione.
  • addGeofence - Monitora una regione circolare iOS o Android.
  • removeGeofence / removeAllGeofences - Fermare la monitorazione di una o tutte le regioni registrate.
  • getMonitoredGeofences - Elencare gli identificatori delle regioni monitorate.
  • geofenceTransition listener - Ricevere eventi di ingresso e uscita mentre l'app è attiva.
  • geofenceError listener - Gestire gli errori di monitorazione nativa separatamente dagli eventi di transizione.

Esempio di utilizzo

start

Per iniziare a ricevere notifiche delle modifiche nella posizione del dispositivo, chiamare questo metodo. Un Promessa viene restituita per indicare che è terminata la chiamata. Il callback verrà chiamato ogni volta che sarà disponibile una nuova posizione, o se è stato verificato un errore durante la chiamata di questo metodo. Non si deve affidare alla rifiutazione della promessa per questo.

import { BackgroundGeolocation } from '@capgo/background-geolocation';

await BackgroundGeolocation.start(
  {
    backgroundMessage: "App is using your location in the background",
    backgroundTitle: "Location Service",
    requestPermissions: true,
    stale: false,
    distanceFilter: 10
  },
  (location, error) => {
    if (error) {
      console.error('Location error:', error);
      return;
    }
    if (location) {
      console.log('New location:', location.latitude, location.longitude);
    }
  }
);

stop

Smette gli aggiornamenti della posizione.

import { BackgroundGeolocation } from '@capgo/background-geolocation';

await BackgroundGeolocation.stop();

openSettings

Apri la pagina di impostazioni della posizione del dispositivo. Utile per dirigere gli utenti a consentire i servizi di posizione o adattare le autorizzazioni.

import { BackgroundGeolocation } from '@capgo/background-geolocation';

// Direct user to location settings
await BackgroundGeolocation.openSettings();

setPlannedRoute

Gioca un file audio quando l'utente si allontana dalla rotta pianificata. Questo dovrebbe essere utilizzato per riprodurre un suono (anche in background, solo per nativo).

import { BackgroundGeolocation } from '@capgo/background-geolocation';

await BackgroundGeolocation.setPlannedRoute({
  soundFile: "notification.mp3",
  route: [[-74.0060, 40.7128], [-118.2437, 34.0522]]
});

Geofencing nativo

Monitora negozi, siti di lavoro, zone di consegna, campus o aree di check-in con geofenci iOS e Android nativi. Aggiungi un HTTP o HTTPS url per consentire ai payload POST nativi di code durante la sospensione del WebView.

import { BackgroundGeolocation } from '@capgo/background-geolocation';

await BackgroundGeolocation.setupGeofencing({
  url: 'https://api.example.com/geofences',
  notifyOnEntry: true,
  notifyOnExit: true,
  payload: { userId: '123' },
});

await BackgroundGeolocation.addGeofence({
  identifier: 'warehouse',
  latitude: 40.7128,
  longitude: -74.006,
  radius: 200,
});

const listener = await BackgroundGeolocation.addListener(
  'geofenceTransition',
  (event) => console.log(event.identifier, event.transition),
);

const errorListener = await BackgroundGeolocation.addListener(
  'geofenceError',
  (event) => console.error(event.identifier, event.message),
);

await BackgroundGeolocation.removeGeofence({ identifier: 'warehouse' });
await listener.remove();
await errorListener.remove();

Aggiungi ACCESS_BACKGROUND_LOCATION solo quando hai bisogno di geofencing di background:

<uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION" />

Riferimento Completo

Continua da Utilizzo di @capgo/geolocalizzazione-di-background

Se stai utilizzando Utilizzo di @capgo/geolocalizzazione-di-background per pianificare il lavoro del plugin nativo, connettilo con @capgo/geolocalizzazione-di-background per i dettagli di implementazione in @capgo/background-geolocation, Inizio per i dettagli di implementazione in Inizio, Capgo Directory dei Plugin per il flusso di lavoro del prodotto in Capgo Directory dei Plugin, Capacitor Plugin da Capgo per i dettagli di implementazione in Capacitor Plugin da Capgo, e Aggiungere o Aggiornare i Plugin per i dettagli di implementazione in Aggiungere o Aggiornare i Plugin.