Les cartes sont représentées dans l'API par la classe GMSMapView
, une sous-classe de UIView
. La carte est l'objet le plus important du SDK Maps pour iOS. Elle fournit les méthodes nécessaires pour ajouter, supprimer et gérer d'autres objets tels que des repères et des polylignes.
Introduction
Le SDK Maps pour iOS vous permet d'afficher une carte Google dans votre application iOS. Ces cartes ont la même apparence que celles que vous voyez dans l'application iOS Google Maps, et le SDK expose de nombreuses fonctionnalités identiques.
En plus des fonctionnalités de cartographie, l'API est également compatible avec un éventail d'interactions conformes au modèle d'UI iOS. Par exemple, vous pouvez configurer des interactions avec une carte en définissant des répondeurs qui réagissent aux gestes de l'utilisateur, tels que le double appui.
La classe principale lors de l'utilisation d'un objet Map est la classe GMSMapView
.
GMSMapView
gère automatiquement les opérations suivantes:
- Connexion au service Google Maps
- Téléchargement des tuiles de carte
- Affichage des tuiles sur l'écran de l'appareil
- Affichage de diverses commandes comme le panoramique et le zoom
- Réponse aux gestes de panoramique et de zoom (déplacement de la carte et zoom avant ou arrière)
- Répondre aux gestes à deux doigts en inclinant l'angle de vue de la carte
En plus de ces opérations automatiques, vous pouvez contrôler le comportement et l'apparence de la carte via les propriétés et les méthodes exposées par la classe GMSMapView
. GMSMapView
vous permet d'ajouter et de supprimer des repères, des superpositions au sol et des polylignes, de modifier le type de carte affiché et de contrôler ce qui est affiché sur la carte via la classe GMSCameraPosition
.
Créer des cartes avec SwiftUI
SwiftUI offre un autre moyen de créer une UI à l'aide d'une approche déclarative. Vous indiquez à SwiftUI à quoi vous voulez que votre vue ressemble, ainsi que tous les différents états, et le système s'occupe du reste. SwiftUI gère la mise à jour de la vue chaque fois que l'état sous-jacent change en raison d'un événement ou d'une action de l'utilisateur.
Le SDK Maps pour iOS est basé sur UIKit
et ne fournit pas de vue compatible avec SwiftUI. L'ajout de cartes dans SwiftUI nécessite de se conformer à UIViewRepresentable
ou UIViewControllerRepresentable
. Pour en savoir plus, consultez l'atelier de programmation Ajouter une carte à votre application iOS avec SwiftUI.
Ajouter une carte
Les principales étapes pour ajouter une carte sont les suivantes :
Pour obtenir le SDK, obtenir une clé API et ajouter les frameworks requis, suivez les étapes décrites dans:
Dans votre
AppDelegate
, fournissez votre clé API à la méthode de classeprovideAPIKey:
surGMSServices
.Créez ou mettez à jour un
ViewController
. Si la carte s'affiche lorsque ce contrôleur de vue devient visible, veillez à la créer dans la méthodeviewDidLoad
.Lorsque vous initialisez la vue de la carte, définissez les options de configuration avec
GMSMapViewOptions
. Les propriétés incluentframe
,camera
,mapID
,backgroundColor
ouscreen
.Définissez la propriété
camera
des options de carte avec un objetGMSCameraPosition
. Cela spécifie le centre et le niveau de zoom de la carte.Créez et instanciez une classe
GMSMapView
à l'aide de la méthodeoptions:
GMSMapView
. Si cette carte doit être utilisée comme seule vue du contrôleur de vue, la valeur par défaut de l'option de carteframe
,CGRectZero
, peut être utilisée comme vueframe
. La carte est redimensionnée automatiquement.Définissez l'objet
GMSMapView
comme vue du contrôleur de vue. Exemple :self.view = mapView;
.
Dans l'exemple ci-dessous, une carte, centrée sur le centre-ville de Singapour, est ajoutée à une application.
Swift
import GoogleMaps class MapObjects : UIViewController { override func viewDidLoad() { super.viewDidLoad() let options = GMSMapViewOptions() options.camera = GMSCameraPosition(latitude: 1.285, longitude: 103.848, zoom: 12) options.frame = self.view.bounds; let mapView = GMSMapView(options:options) self.view = mapView } }
Objective-C
- (void)viewDidLoad { [super viewDidLoad]; GMSMapViewOptions *options = [[GMSMapViewOptions alloc] init]; options.camera = [GMSCameraPosition cameraWithLatitude:1.285 longitude:103.848 zoom:12]; options.frame = self.view.bounds; GMSMapView *mapView = [[GMSMapView alloc] initWithOptions:options]; self.view = mapView; }
Une fois que vous avez suivi ces étapes, vous pouvez configurer davantage l'objet GMSMapView
.
Étape suivante
Une fois cette procédure terminée, vous pouvez configurer les paramètres de la carte.