Dopo aver attivato la fatturazione e creato una chiave API, puoi configurare il progetto Xcode utilizzato per sviluppare l'app.
Per ogni release sono disponibili le note di rilascio.
Passaggio 1: installa il software necessario
Per creare un progetto utilizzando Maps SDK for iOS, devi scaricare e installare:
- Xcode versione 15.0 o successive
Passaggio 2: crea il progetto Xcode e installa Maps SDK for iOS
Swift Package Manager
L'SDK Maps per iOS può essere installato tramite Swift Package Manager. Per aggiungere l'SDK, assicurati di aver rimosso eventuali dipendenze di Maps SDK for iOS esistenti.
Per aggiungere l'SDK a un progetto nuovo o esistente:
-
Apri Xcode
project
oworkspace
, quindi vai a File > Aggiungi dipendenze del pacchetto. - Inserisci https://github.com/googlemaps/ios-maps-sdk come URL, premi Invio per importare il pacchetto e fai clic su "Aggiungi pacchetto".
-
Per installare un
version
specifico, imposta il campo Regola di dipendenza su una delle opzioni basate sulla versione. Per i nuovi progetti, ti consigliamo di specificare la versione più recente e di utilizzare l'opzione "Versione esatta". Al termine, fai clic su "Aggiungi pacchetto".
Per aggiornare il package
di un progetto esistente:
Se esegui l'upgrade da una versione precedente alla 9.0.0, devi rimuovere le seguenti dipendenze:
GoogleMapsBase
,GoogleMapsCore
eGoogleMapsM4B
dopo l'upgrade. Non rimuovere la dipendenza perGoogleMaps
. Per ulteriori informazioni, consulta le note di rilascio della versione 9.0.0.Nelle impostazioni di configurazione del progetto Xcode, individua Framework, librerie e contenuti incorporati. Utilizza il segno meno(-) per rimuovere il seguente framework:
GoogleMapsBase
(solo per gli upgrade da versioni precedenti alla 9.0.0)GoogleMapsCore
(solo per gli upgrade da versioni precedenti alla 9.0.0)GoogleMapsM4B
(solo per gli upgrade da versioni precedenti alla 9.0.0)
- In Xcode, vai a "File > Pacchetti > Aggiorna alle versioni più recenti dei pacchetti".
- Per verificare l'installazione, vai alla sezione Dipendenze del pacchetto di Project Navigator per verificare il pacchetto e la relativa versione.
Per rimuovere le dipendenze esistenti di Maps SDK for iOS aggiunte utilizzando CocoaPods
, segui questi passaggi:
- Chiudi l'area di lavoro Xcode. Apri il terminale ed esegui il seguente comando:
sudo gem install cocoapods-deintegrate cocoapods-clean pod deintegrate pod cache clean --all
-
Rimuovi
Podfile
,Podfile.resolved
e Xcodeworkspace
se non li utilizzi per altro che per CocoaPods.
-
Nelle impostazioni di configurazione del progetto Xcode, individua Framework, librerie e contenuti incorporati. Utilizza il segno meno(-) per rimuovere il seguente framework:
GoogleMaps
GoogleMapsBase
(solo per installazioni precedenti alla versione 9.2.0)GoogleMapsCore
(solo per installazioni precedenti alla versione 9.2.0)GoogleMapsM4B
(solo per installazioni precedenti alla versione 9.0.0)
-
Dalla directory di primo livello del progetto Xcode, rimuovi il
GoogleMaps
bundle.
Installazione manuale
Questa guida mostra come aggiungere manualmente al progetto gli XCFramework contenenti il Maps SDK for iOS e configurare le impostazioni di compilazione in Xcode. Un XCFramework è un pacchetto binario che puoi utilizzare su più piattaforme, incluse le macchine che utilizzano Apple Silicon.
- Scarica i seguenti file di risorse e binari dell'SDK:
- Estrai i file per accedere agli XCFrameworks e alle risorse.
- Se non hai ancora un progetto Xcode, creane uno ora e salvalo sulla tua macchina locale. Se non hai esperienza di sviluppo per iOS:
- Crea un nuovo progetto.
- Seleziona il modello iOS > App.
- Nella schermata delle opzioni del progetto:
- Inserisci il nome del progetto.
- Registra il valore del campo Identificatore pacchetto. Puoi utilizzare questo valore per limitare la tua chiave API di seguito.
- Imposta l'interfaccia del progetto su Storyboard.
- Imposta Lingua su Swift o Objective-C.
-
Apri la scheda Generale. Trascina il seguente XCFramework nel progetto
in Framework, librerie e contenuti incorporati. Assicurati di selezionare Non incorporare:
GoogleMaps.xcframework
-
Copia
GoogleMaps.bundle
da GoogleMapsResources che hai scaricato nella directory di primo livello del progetto Xcode. Assicurati di selezionare Copia elementi nella cartella del gruppo di destinazione quando richiesto. - Seleziona il progetto dal Navigatore progetti e scegli la destinazione dell'applicazione.
-
Apri la scheda Fasi di compilazione per il target della tua applicazione.
In Collega il file binario alle librerie, aggiungi i seguenti
framework e librerie:
Accelerate.framework
Contacts.framework
CoreData.framework
CoreGraphics.framework
CoreImage.framework
CoreLocation.framework
CoreTelephony.framework
CoreText.framework
GLKit.framework
ImageIO.framework
libc++.tbd
libz.tbd
Metal.framework
OpenGLES.framework
(solo se utilizzi OpenGL)QuartzCore.framework
Security.framework
SystemConfiguration.framework
UIKit.framework
-
Scegli il progetto anziché un target specifico e apri la scheda Impostazioni di compilazione. Nella sezione Linking - General -> Other Linker Flags, aggiungi
-ObjC
a "Debug" e "Release". Se queste impostazioni non sono visibili, modifica il filtro nella barra Impostazioni di compilazione da Base a Tutte. -
Per installare l'XCFramework di Places SDK for iOS, consulta Iniziare a utilizzare Places SDK for iOS.
CocoaPods
Maps SDK for iOS è disponibile come CocoaPods. CocoaPods è un gestore delle dipendenze open source per progetti Cocoa in Swift e Objective-C.
Se non hai già lo strumento CocoaPods, installalo su macOS eseguendo il seguente comando dal terminale. Per maggiori dettagli, consulta la guida introduttiva di CocoaPods.
sudo gem install cocoapods
Crea un Podfile
per Maps SDK for iOS e utilizzalo per installare l'API e le relative dipendenze:
- Se non hai ancora un progetto Xcode, creane uno ora e salvalo sulla tua macchina locale. Se non hai esperienza nello sviluppo per iOS:
- Crea un nuovo progetto.
- Seleziona il modello iOS > App.
- Nella schermata delle opzioni del progetto:
- Inserisci il nome del progetto.
- Registra il valore del campo Identificatore pacchetto. Puoi utilizzare questo valore per limitare la tua chiave API di seguito.
- Imposta l'interfaccia del progetto su Storyboard.
- Imposta Lingua su Swift o Objective-C.
- Crea un file denominato
Podfile
nella directory del progetto. Questo file definisce le dipendenze del progetto. - Modifica il file
Podfile
e aggiungi le dipendenze con le rispettive versioni. Ecco un esempio che include la dipendenza necessaria per Maps SDK for iOS: Assicurati di eseguire regolarmentesource 'https://github.com/CocoaPods/Specs.git' platform :ios, '15.0' target 'YOUR_APPLICATION_TARGET_NAME_HERE' do pod 'GoogleMaps', '9.2.0' end
pod outdated
per rilevare se è disponibile una versione più recente e assicurarti di avere sempre la versione più recente. Se necessario, esegui l'upgrade all'ultima versione. - Salva il
Podfile
. Apri un terminale e vai alla directory contenente
Podfile
:cd <path-to-project>
Esegui il comando
pod install
. Verranno installate le API specificate nel filePodfile
, insieme a eventuali dipendenze.pod install
Chiudi Xcode, quindi apri (fai doppio clic) il file
.xcworkspace
del progetto per avviare Xcode. Da questo momento in poi, dovrai utilizzare il file.xcworkspace
per aprire il progetto.
Per aggiornare l'API per un progetto esistente:
- Apri un terminale e vai alla directory del progetto contenente il file
Podfile
. - Esegui il comando
pod update
. In questo modo, tutte le API specificate inPodfile
verranno aggiornate all'ultima versione.
Passaggio 3: aggiungi la chiave API al progetto
In Ottieni una chiave API, hai gerado una chiave API per la tua app. Ora aggiungila al progetto Xcode.
Nei seguenti esempi, sostituisci YOUR_API_KEY
con la tua chiave API.
Swift
Aggiungi la chiave API a AppDelegate.swift
come segue:
- Aggiungi la seguente istruzione di importazione:
import GoogleMaps
- Aggiungi quanto segue al metodo
application(_:didFinishLaunchingWithOptions:)
utilizzando la tua chiave API:GMSServices.provideAPIKey("YOUR_API_KEY")
- Se utilizzi anche l'API Places, aggiungi di nuovo la chiave come mostrato di seguito:
GMSPlacesClient.provideAPIKey("YOUR_API_KEY")
Objective-C
Aggiungi la chiave API a AppDelegate.m
come segue:
- Aggiungi la seguente istruzione di importazione:
@import GoogleMaps;
- Aggiungi quanto segue al metodo
application:didFinishLaunchingWithOptions:
utilizzando la tua chiave API:[GMSServices provideAPIKey:@"YOUR_API_KEY"];
- Se utilizzi anche l'API Places, aggiungi di nuovo la chiave come mostrato di seguito:
[GMSPlacesClient provideAPIKey:@"YOUR_API_KEY"];
(Facoltativo) Passaggio 4: controlla il file manifest della privacy di Apple
Apple richiede dettagli sulla privacy delle app per le app sull'App Store. Per aggiornamenti e ulteriori informazioni, visita la pagina relativa all'Informativa sulla privacy delle app dell'App Store di Apple.
Il file manifest della privacy di Apple è incluso nel bundle di risorse per l'SDK. Per verificare che il file manifest della privacy sia stato incluso e per ispezionarne i contenuti, crea un archivio della tua app e genera un report sulla privacy dall'archivio.
(Facoltativo) Passaggio 5: dichiara gli schemi URL utilizzati dall'API
A partire da iOS 9 e Xcode 7, le app possono dichiarare gli schemi URL che hanno intenzione di aprire specificandoli nel file Info.plist
dell'app. Maps SDK for iOS apre l'app mobile Google Maps quando l'utente fa clic sul logo Google sulla mappa, pertanto la tua app può dichiarare gli schemi URL pertinenti.
Per dichiarare gli schemi URL utilizzati da Maps SDK for iOS, aggiungi le seguenti righe a Info.plist
:
<key>LSApplicationQueriesSchemes</key>
<array>
<string>googlechromes</string>
<string>comgooglemaps</string>
</array>
Lo screenshot seguente mostra la configurazione nell'interfaccia utente di Xcode:
Senza la dichiarazione precedente, quando l'utente tocca il logo di Google sulla mappa possono verificarsi i seguenti errori:
-canOpenURL: failed for URL: "comgooglemaps://" - error: "This app is not allowed to query for scheme comgooglemaps"
-canOpenURL: failed for URL: "googlechromes://" - error: "This app is not allowed to query for scheme googlechromes"
Per eliminare questi errori, aggiungi la dichiarazione al tuo Info.plist
.
Passaggi successivi
Ora che hai una chiave API e un progetto Xcode, puoi creare ed eseguire app. L'SDK Navigation per iOS fornisce molti tutorial e app di esempio che possono aiutarti a iniziare. Per maggiori dettagli, vedi:
- I seguenti tutorial sono punti di partenza consigliati:
- Consulta gli esempi di codice e i codelabs disponibili.
- Per soluzioni end-to-end, consulta le soluzioni Maps disponibili.