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.geofenceTransitionlistener - Ricevere eventi di ingresso e uscita mentre l'app è attiva.geofenceErrorlistener - 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
- GitHub: https://github.com/Cap-go/capacitor-geolocalizzazione-di-background/
- Documentazione: /docs/plugins/geolocalizzazione-di-background/
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.