Adicionar um marcador ao mapa

Este exemplo mostra um mapa com alfinetes para marcadores em Sydney e Melbourne, Austrália.

Primeiros passos

Antes de testar o exemplo de código, é necessário configurar o ambiente de desenvolvimento. Confira mais detalhes em Exemplos de código do SDK do Maps para iOS.

Ver o código

Swift

import GoogleMaps import UIKit  // Sample code for adding a marker. class MarkersViewController: UIViewController {   private lazy var sydneyMarker = GMSMarker(     position: CLLocationCoordinate2D(latitude: -33.8683, longitude: 151.2086))    private lazy var melbourneMarker = GMSMarker(     position: CLLocationCoordinate2D(latitude: -37.81969, longitude: 144.966085))    private lazy var mapView: GMSMapView = {     let camera = GMSCameraPosition(latitude: -37.81969, longitude: 144.966085, zoom: 4)     return GMSMapView(frame: .zero, camera: camera)   }()    override func loadView() {     view = mapView      sydneyMarker.title = "Sydney"     sydneyMarker.snippet = "Population: 4,605,992"     sydneyMarker.isFlat = false     sydneyMarker.rotation = 30     print("sydneyMarker: \(sydneyMarker)")      let australiaMarker = GMSMarker(       position: CLLocationCoordinate2D(latitude: -27.994401, longitude: 140.07019))     australiaMarker.title = "Australia"     australiaMarker.appearAnimation = .pop     australiaMarker.isFlat = true     australiaMarker.isDraggable = true     australiaMarker.groundAnchor = CGPoint(x: 0.5, y: 0.5)     australiaMarker.icon = UIImage(named: "australia")     australiaMarker.map = mapView      mapView.selectedMarker = sydneyMarker     navigationItem.rightBarButtonItem = UIBarButtonItem(       barButtonSystemItem: .add, target: self, action: #selector(tapAdd))   }    @objc func tapAdd() {     if sydneyMarker.map == nil {       sydneyMarker.map = mapView     } else {       sydneyMarker.map = nil     }     melbourneMarker.title = "Melbourne"     melbourneMarker.snippet = "Population: 4,169,103"     melbourneMarker.map = mapView   } }       

Objective-C

#import "GoogleMapsDemos/Samples/MarkersViewController.h"  #import <GoogleMaps/GoogleMaps.h>  @implementation MarkersViewController {   GMSMarker *_sydneyMarker;   GMSMarker *_melbourneMarker;   GMSMarker *_fadeInMarker; }  - (void)viewDidLoad {   [super viewDidLoad];   GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-37.81969                                                           longitude:144.966085                                                                zoom:4];   GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera];    _sydneyMarker = [[GMSMarker alloc] init];   _sydneyMarker.title = @"Sydney";   _sydneyMarker.snippet = @"Population: 4,605,992";   _sydneyMarker.position = CLLocationCoordinate2DMake(-33.8683, 151.2086);   _sydneyMarker.flat = NO;   _sydneyMarker.rotation = 30.0;   NSLog(@"sydneyMarker: %@", _sydneyMarker);    GMSMarker *australiaMarker = [[GMSMarker alloc] init];   australiaMarker.title = @"Australia";   australiaMarker.position = CLLocationCoordinate2DMake(-27.994401, 140.07019);   australiaMarker.appearAnimation = kGMSMarkerAnimationPop;   australiaMarker.flat = YES;   australiaMarker.draggable = YES;   australiaMarker.groundAnchor = CGPointMake(0.5, 0.5);   australiaMarker.icon = [UIImage imageNamed:@"australia"];   australiaMarker.map = mapView;    _fadeInMarker = [[GMSMarker alloc] init];   _fadeInMarker.title = @"Australia";   _fadeInMarker.position = CLLocationCoordinate2DMake(-29.9959, 145.0719);   _fadeInMarker.appearAnimation = kGMSMarkerAnimationFadeIn;   _fadeInMarker.icon = [UIImage imageNamed:@"australia"];    // Set the marker in Sydney to be selected   mapView.selectedMarker = _sydneyMarker;    self.view = mapView;   self.navigationItem.rightBarButtonItem =       [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemAdd                                                     target:self                                                     action:@selector(didTapAdd)]; }  - (void)didTapAdd {   if (_sydneyMarker.map == nil) {     _sydneyMarker.map = (GMSMapView *)self.view;   } else {     _sydneyMarker.map = nil;   }    _melbourneMarker.map = nil;   _melbourneMarker = [[GMSMarker alloc] init];   _melbourneMarker.title = @"Melbourne";   _melbourneMarker.snippet = @"Population: 4,169,103";   _melbourneMarker.position = CLLocationCoordinate2DMake(-37.81969, 144.966085);   _melbourneMarker.map = (GMSMapView *)self.view;    if (_fadeInMarker.map) {     _fadeInMarker.map = nil;   } else {     _fadeInMarker.map = (GMSMapView *)self.view;   } }  @end       

Executar o app de exemplo completo localmente

O app de exemplo do SDK do Maps para iOS está disponível como um arquivo de download no GitHub. Siga estas etapas para instalar e testar o app de exemplo do SDK do Maps para iOS.

  1. Execute git clone https://github.com/googlemaps-samples/maps-sdk-for-ios-samples.git para clonar o repositório de amostras em um diretório local.
  2. Abra uma janela de terminal, navegue até o diretório em que você clonou os arquivos de amostra e navegue até o diretório GoogleMaps:

    Swift

    cd maps-sdk-for-ios-samples-main/GoogleMaps-Swift pod install open GoogleMapsSwiftDemos.xcworkspace

    Objective-C

    cd maps-sdk-for-ios-samples-main/GoogleMaps pod install open GoogleMapsDemos.xcworkspace
  3. No Xcode, pressione o botão de compilação para criar o app com o esquema atual. O build gera um erro, solicitando que você insira a chave de API no arquivo SDKConstants.swift para Swift ou SDKDemoAPIKey.h para Objective-C.
  4. Gerar uma chave de API no seu projeto com o SDK do Maps para iOS ativado.
  5. Edite o arquivo SDKConstants.swift para Swift ouSDKDemoAPIKey.h para Objective-C e cole a chave de API na definição da constante apiKey ou kAPIKey. Exemplo:

    Swift

    static let apiKey = "YOUR_API_KEY"

    Objective-C

    static NSString *const kAPIKey = @"YOUR_API_KEY";
  6. No arquivo SDKConstants.swift (Swift) ou SDKDemoAPIKey.h (Objective-C), remova a seguinte linha, porque ela é usada para registrar o problema definido pelo usuário:

    Swift

    #error (Register for API Key and insert here. Then delete this line.)

    Objective-C

    #error Register for API Key and insert here.
  7. Compile e execute o projeto. A janela do simulador do iOS aparece mostrando uma lista de demonstrações do SDK do Maps.
  8. Escolha uma das opções exibidas para testar um recurso do SDK do Maps para iOS.
  9. Se você receber uma solicitação para permitir que o GoogleMapsDemos acesse seu local, escolha Permitir.