Каждый GMSMarker
имеет свойство карты, то есть карту, на которой оно должно быть отображено.
Вот полезный класс:
class MyCustomMap: GMSMapView {
var markers: [Marker] = [] // array of custom marker to be shown in the map
var defaultZoom: Float = 10 //default zoom level of the map
override func awakeFromNib() {
super.awakeFromNib()
settings.rotateGestures = true
isMyLocationEnabled = true
settings.setAllGesturesEnabled(true)
}
func removeAllMarkers() {
for eachMarker in markers {
eachMarker.map = nil
}
}
/// Sets the zoom level of the map to show all the marker at once with in the screen
func showAllMarkers(for markers: [Marker]) {
var bounds = GMSCoordinateBounds()
for marker in markers {
bounds = bounds.includingCoordinate(marker.position)
}
let update = GMSCameraUpdate.fit(bounds, withPadding: 100.0)
animate(with: update)
}
// MARK: - Private
func createMarker(with marker: Marker) {
markers.append(marker)
marker.map = self
}
func createMarkers(with markers: [Marker]) {
for eachMarker in markers {
createMarker(with: eachMarker)
}
}
}
Здесь маркер - это мой пользовательский маркер, которыйнаследует GMSMarker
class Marker : GMSMarker {
}
Кроме того, если вы пытаетесь показать маркер в вашем текущем местоположении после его получения, создайте новый маркер с CLLocationCoordinate2D
широтой и долготой и добавьте его на карту.
marker.map = your_mapview