Skip to main content

Add live data

A newer version of the Maps SDK is available

This page uses v6.4.1 of the Mapbox Maps SDK. A newer version of the SDK is available. Learn about the latest version, v11.3.0, in the Maps SDK documentation.

ViewController
import Mapbox

class LiveDataExample: UIViewController, MGLMapViewDelegate {

var source: MGLShapeSource!
var timer = Timer()
override func viewDidLoad() {
super.viewDidLoad()

// Create a new map view using the Mapbox Dark style.
let mapView = MGLMapView(frame: view.bounds,
styleURL: MGLStyle.darkStyleURL(withVersion: 9))
mapView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
mapView.tintColor = .gray

// Set the map view‘s delegate property.
mapView.delegate = self
view.addSubview(mapView)
}

func mapView(_ mapView: MGLMapView, didFinishLoading style: MGLStyle) {
if let url = URL(string: "https://wanderdrone.appspot.com/") {
// Add a source to the map. https://wanderdrone.appspot.com/ generates coordinates for simulated paths.
source = MGLShapeSource(identifier: "wanderdrone", url: url, options: nil)
style.addSource(source)

// Add a Maki icon to the map to represent the drone's coordinate. The specified icon is included in the Mapbox Dark style's sprite sheet. For more information about Maki icons, see https://www.mapbox.com/maki-icons/
let droneLayer = MGLSymbolStyleLayer(identifier: "wanderdrone", source: source)
droneLayer.iconImageName = NSExpression(forConstantValue: "rocket-15")
droneLayer.iconHaloColor = NSExpression(forConstantValue: UIColor.white)
style.addLayer(droneLayer)

// Create a timer that calls the `updateUrl` function every 1.5 seconds.
timer.invalidate()
timer = Timer.scheduledTimer(timeInterval: 1.5, target: self, selector: #selector(updateUrl), userInfo: nil, repeats: true)
}
}

@objc func updateUrl() {
// Update the icon's position by setting the `url` property on the source.
source.url = source.url
}

override func viewWillDisappear(_ animated: Bool) {
// Invalidate the timer if the view will disappear.
timer.invalidate()
timer = Timer()
}
}