Aggiungi una mappa con un indicatore

Questo tutorial mostra come aggiungere una semplice mappa di Google con un indicatore alla tua app per iOS. È adatto a persone con una conoscenza di base o intermedia di Swift o Obiettivo-C oltre a una conoscenza generale di Xcode. Per una guida avanzata alla creazione di mappe, leggi la guida per gli sviluppatori.

Utilizzando questo tutorial, creerai la mappa seguente. L'indicatore è posizionato a Sydney, Australia.

Uno screenshot che mostra una mappa con un indicatore sopra Sydney

Ottieni il codice

Clona o scarica il repository di esempi di Google Maps per iOS su GitHub.

In alternativa, fai clic sul seguente pulsante per scaricare il codice sorgente:

Dammi il codice

Swift

/*
 * Copyright 2020 Google Inc. All rights reserved.
 *
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this
 * file except in compliance with the License. You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under
 * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
 * ANY KIND, either express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */

import UIKit
import GoogleMaps

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.
        // Create a GMSCameraPosition that tells the map to display the
        // coordinate -33.86,151.20 at zoom level 6.
        let camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 6.0)
        let mapView = GMSMapView.map(withFrame: self.view.frame, camera: camera)
        self.view.addSubview(mapView)

        // Creates a marker in the center of the map.
        let marker = GMSMarker()
        marker.position = CLLocationCoordinate2D(latitude: -33.86, longitude: 151.20)
        marker.title = "Sydney"
        marker.snippet = "Australia"
        marker.map = mapView
  }
}

      

Objective-C

/*
* Copyright 2020 Google Inc. All rights reserved.
*
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this
* file except in compliance with the License. You may obtain a copy of the License at
*
*     http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
* ANY KIND, either express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/

#import "ViewController.h"
#import <GoogleMaps/GoogleMaps.h>

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
  // Do any additional setup after loading the view.
  // Create a GMSCameraPosition that tells the map to display the
  // coordinate -33.86,151.20 at zoom level 6.
  GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.86
                                                          longitude:151.20
                                                               zoom:6];
  GMSMapView *mapView = [GMSMapView mapWithFrame:self.view.frame camera:camera];
  mapView.myLocationEnabled = YES;
  [self.view addSubview:mapView];

  // Creates a marker in the center of the map.
  GMSMarker *marker = [[GMSMarker alloc] init];
  marker.position = CLLocationCoordinate2DMake(-33.86, 151.20);
  marker.title = @"Sydney";
  marker.snippet = @"Australia";
  marker.map = mapView;
}

@end

      

Inizia

Gestione pacchetti Swift

Maps SDK for iOS può essere installato utilizzando Swift Package Manager.

  1. Assicurati di aver rimosso eventuali SDK Maps per le dipendenze iOS esistenti.
  2. Apri una finestra del terminale e vai alla directory tutorials/mapwithmarker.
  3. Assicurati che l'area di lavoro Xcode sia chiusa ed esegui questi comandi:
    sudo gem install cocoapods-deintegrate cocoapods-clean
    pod deintegrate
    pod cache clean --all
    rm Podfile
    rm map-with-marker.xcworkspace
  4. Apri il progetto Xcode ed elimina il podfile.
  5. Vai a File > Aggiungi dipendenze pacchetto.
  6. Inserisci https://github.com/googlemaps/ios-maps-sdk come URL, premi Invio per estrarre il pacchetto e fai clic su Aggiungi pacchetto.
  7. Potresti dover reimpostare la cache del pacchetto utilizzando File > Pacchetti > Reimposta cache pacchetto.

Utilizzare CocoaPods

  1. Scarica e installa Xcode 14.0 o versioni successive.
  2. Se non hai ancora CocoaPods, installalo su macOS eseguendo questo comando dal terminale:
    sudo gem install cocoapods
  3. Vai alla directory tutorials/map-with-marker.
  4. Esegui il comando pod install. Verrà installato l'SDK Maps specificato in Podfile, insieme a eventuali dipendenze.
  5. Esegui pod outdated per confrontare la versione del pod installata con eventuali nuovi aggiornamenti. Se viene rilevata una nuova versione, esegui pod update per aggiornare Podfile e installare l'SDK più recente. Per maggiori dettagli, consulta la guida di CocoaPods.
  6. Apri (fai doppio clic) il file map-with-flag.xcworkspace del progetto per aprirlo in Xcode. Devi usare il file .xcworkspace per aprire il progetto.

Ottieni una chiave API e abilita le API necessarie

Per completare questo tutorial, ti serve una chiave API di Google autorizzata a utilizzare Maps SDK for iOS. Fai clic sul pulsante seguente per ottenere una chiave e attivare l'API.

Inizia

Per maggiori dettagli, consulta Ottenere una chiave API.

Aggiungi la chiave API all'applicazione

Aggiungi la tua chiave API a AppDelegate.swift come segue:

  1. Tieni presente che la seguente istruzione di importazione è stata aggiunta al file:
    import GoogleMaps
  2. Modifica la riga seguente nel tuo metodo application(_:didFinishLaunchingWithOptions:), sostituendo YOUR_API_KEY con la tua chiave API:
    GMSServices.provideAPIKey("YOUR_API_KEY")

Crea ed esegui la tua app

  1. Collega un dispositivo iOS al computer oppure seleziona un simulatore dal menu dello schema Xcode.
  2. Se usi un dispositivo, assicurati che i servizi di geolocalizzazione siano attivi. Se utilizzi un simulatore, seleziona una località dal menu Funzionalità.
  3. In Xcode, fai clic sull'opzione di menu Prodotto/Esegui (o sull'icona del pulsante di riproduzione).
    • Xcode crea l'app, quindi la esegue sul dispositivo o sul simulatore.
    • Dovresti visualizzare una mappa con un indicatore centrato su Sydney, sulla costa orientale dell'Australia, simile all'immagine in questa pagina.

Risoluzione dei problemi:

  • Se non visualizzi una mappa, verifica di aver ottenuto una chiave API e di averla aggiunta all'app, come descritto in precedenza. Controlla la console di debug di Xcode per eventuali messaggi di errore sulla chiave API.
  • Se hai limitato la chiave API in base all'identificatore pacchetto iOS, modificala per aggiungere l'identificatore pacchetto per l'app: com.google.examples.map-with-marker.
  • Assicurati di avere una buona connessione Wi-Fi o GPS.
  • Utilizza gli strumenti di debug Xcode per visualizzare i log ed eseguire il debug dell'app.

comprendi il codice

  1. Crea una mappa e impostala come visualizzazione in viewDidLoad().

    Swift

    // Create a GMSCameraPosition that tells the map to display the
    // coordinate -33.86,151.20 at zoom level 6.
    let camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 6.0)
    let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera)
    view = mapView
          

    Objective-C

    // Create a GMSCameraPosition that tells the map to display the
    // coordinate -33.86,151.20 at zoom level 6.
    GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.86
                                                            longitude:151.20
                                                                 zoom:6.0];
    GMSMapView *mapView = [[GMSMapView alloc] initWithFrame: CGRectZero camera:camera];
    self.view = mapView;
          
  2. Aggiungi un indicatore alla mappa in viewDidLoad().

    Swift

    // Creates a marker in the center of the map.
    let marker = GMSMarker()
    marker.position = CLLocationCoordinate2D(latitude: -33.86, longitude: 151.20)
    marker.title = "Sydney"
    marker.snippet = "Australia"
    marker.map = mapView
          

    Objective-C

    // Creates a marker in the center of the map.
    GMSMarker *marker = [[GMSMarker alloc] init];
    marker.position = CLLocationCoordinate2DMake(-33.86, 151.20);
    marker.title = @"Sydney";
    marker.snippet = @"Australia";
    marker.map = mapView;
          

Per impostazione predefinita, Maps SDK for iOS mostra il contenuto della finestra informativa quando l'utente tocca un indicatore. Non è necessario aggiungere un listener di clic per l'indicatore se vuoi utilizzare il comportamento predefinito.

Congratulazioni! Hai creato un'app per iOS che visualizza una mappa di Google con un indicatore per indicare una determinata posizione. Hai anche imparato a utilizzare Maps SDK for iOS.

Passaggi successivi

Scopri di più sull'oggetto mappa e su cosa puoi fare con gli indicatori.