Karten werden in der API durch die Klasse GMSMapView
dargestellt, die eine abgeleitete Klasse von UIView
ist. Die Karte ist das wichtigste Objekt im Maps SDK for iOS und bietet die erforderlichen Methoden zum Hinzufügen, Entfernen und Verwalten anderer Objekte wie Markierungen und Polylinien.
Einführung
Mit dem Maps SDK for iOS können Sie eine Google-Karte in Ihrer iOS-Anwendung darstellen. Diese Karten sehen genauso aus wie in der Google Maps iOS App und das SDK stellt viele derselben Funktionen bereit.
Zusätzlich zur Kartendarstellungsfunktion unterstützt die API auch zahlreiche Interaktionen, die mit dem iOS-UI-Modell kompatibel sind. Zum Einrichten von Interaktionen mit einer Karte kannst du zum Beispiel Responder definieren, die auf Nutzergesten wie Tippen und Doppeltippen reagieren.
Die wichtigste Klasse bei einem Kartenobjekt ist die Klasse GMSMapView
.
GMSMapView
verarbeitet die folgenden Vorgänge automatisch:
- Verbindung zum Google Maps-Dienst herstellen
- Kartenkacheln herunterladen
- Kacheln auf dem Gerätebildschirm anzeigen
- Verschiedene Steuerelemente anzeigen, z. B. zum Schwenken und Zoomen
- Auf Touch-Gesten zum Schwenken und Zoomen reagieren, indem die Karte verschoben oder heran- bzw. herausgezoomt wird
- Reagieren auf Zwei-Finger-Gesten durch Neigen des Betrachtungswinkels der Karte.
Zusätzlich zu diesen automatischen Vorgängen können Sie das Verhalten und die Darstellung der Karte über die Eigenschaften und Methoden der Klasse GMSMapView
steuern. Mit GMSMapView
können Sie Markierungen, Boden-Overlays und Polylinien hinzufügen und entfernen, den angezeigten Kartentyp ändern und mit der Klasse GMSCameraPosition
festlegen, was auf der Karte angezeigt wird.
Karten mit SwiftUI erstellen
SwiftUI bietet eine zusätzliche Möglichkeit, Benutzeroberflächen mit einem deklarativen Ansatz zu erstellen. Sie geben SwiftUI vor, wie Ihre Ansicht aussehen soll, und zwar für alle verschiedenen Zustände, und das System erledigt den Rest. SwiftUI aktualisiert die Ansicht, wenn sich der zugrunde liegende Status aufgrund eines Ereignisses oder einer Nutzeraktion ändert.
Das Maps SDK for iOS basiert auf UIKit
und bietet keine SwiftUI-kompatible Ansicht. Wenn Sie Karten in SwiftUI einfügen möchten, müssen Sie entweder UIViewRepresentable
oder UIViewControllerRepresentable
entsprechen. Weitere Informationen finden Sie im Codelab zum Hinzufügen einer Karte zu Ihrer iOS-App mit SwiftUI.
Karte hinzufügen
Das Hinzufügen einer Karte umfasst die folgenden grundlegenden Schritte:
Um das SDK zu erhalten, müssen Sie einen API-Schlüssel anfordern und die erforderlichen Frameworks hinzufügen. Folgen Sie dazu den Anleitungen unter:
Geben Sie in Ihrem
AppDelegate
Ihren API-Schlüssel für die KlassenmethodeprovideAPIKey:
inGMSServices
an.Erstellen oder aktualisieren Sie eine
ViewController
. Wenn die Karte angezeigt wird, sobald dieser Ansichtscontroller sichtbar wird, müssen Sie sie in der MethodeviewDidLoad
erstellen.Legen Sie beim Initialisieren der Kartenansicht Konfigurationsoptionen mit
GMSMapViewOptions
fest. Zu den Attributen gehörenframe
,camera
,mapID
,backgroundColor
oderscreen
.Legen Sie die Eigenschaft
camera
Ihrer Kartenoptionen mit einemGMSCameraPosition
-Objekt fest. Damit werden die Mitte und die Zoomstufe der Karte festgelegt.Erstellen und instanziieren Sie eine
GMSMapView
-Klasse mit der MethodeGMSMapView
options:
. Wenn diese Karte als einzige Ansicht des Ansichts-Controllers verwendet werden soll, kann der StandardwertCGRectZero
der Kartenoptionframe
als Ansichtframe
verwendet werden. Die Größe der Karte wird automatisch angepasst.Legen Sie das Objekt
GMSMapView
als Ansicht des View-Controllers fest. Beispiel:self.view = mapView;
Im folgenden Beispiel wird eine Karte mit der Innenstadt von Singapur in der Mitte zu einer App hinzugefügt.
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; }
Nachdem Sie diese Schritte ausgeführt haben, können Sie das GMSMapView
-Objekt weiter konfigurieren.
Nächste Schritte
Nachdem Sie die Schritte oben abgeschlossen haben, können Sie die Karteneinstellungen konfigurieren.