Add live data

import Mapbox
class LiveDataExample: UIViewController, MGLMapViewDelegate {
var source : MGLShapeSource!
var timer = Timer()
override func 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
func mapView(_ mapView: MGLMapView, didFinishLoading style: MGLStyle)
if let url = URL(string: "") {
// Add a source to the map. generates coordinates for simulated paths.
source = MGLShapeSource(identifier: "wanderdrone", url: url, options: nil)
// 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
let droneLayer = MGLSymbolStyleLayer(identifier: "wanderdrone", source: source)
droneLayer.iconImageName = NSExpression(forConstantValue: "rocket-15")
droneLayer.iconHaloColor = NSExpression(forConstantValue: UIColor.white)
// Create a timer that calls the `updateUrl` function every 1.5 seconds.
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 = Timer()