-
Notifications
You must be signed in to change notification settings - Fork 318
Upgrading from v1.x to v2.0.x
Mapbox Navigation SDK for iOS v2.0.0 is a major new version of the SDK. To upgrade, follow the installation instructions. Note that the MapboxNavigation framework’s Carthage support has been discontinued in favor of Swift Package Manager. If you decide to keep using Carthage for the MapboxCoreNavigation framework, you will need to migrate from framework bundles to XCFrameworks.
Starting with version v2.0.0, you can choose from two new pricing options depending on your use case: per-trip or unlimited trips. Also, the Mapbox Navigation SDK is licensed under the Mapbox Terms of Service, a proprietary license. It is no longer available under the permissive ISC License.
Version 2.0.0 includes numerous important changes to the public APIs of the MapboxNavigation and MapboxCoreNavigation frameworks as well as their dependencies. There are several backwards-incompatible changes to be aware of as you upgrade, which are discussed below and divided by framework so that you can upgrade different portions of your application at different times.
- Supported dependency managers:
- Swift Package Manager (new)
- CocoaPods
- Carthage (MapboxCoreNavigation only; MapboxNavigation and mapbox-directions-swift command line tool no longer supported)
- Minimum Xcode version required to build the SDK: 12.4 (11.x no longer supported)
- Minimum iOS deployment target: 11.0 (10.x no longer supported)
Turf v2 revamps the GeoJSON types to better conform to the GeoJSON specification. Please consult the Turf v2.0.0 release notes, which details changes to the type system and examples for upgrading.
GeoJSON is now represented using Turf types throughout Mapbox’s SDKs, including in the map SDK’s public API, so it is no longer necessary to convert between Turf GeoJSON types and the map SDK’s shape types.
- The preferred way to set your Mapbox access token is to set the
MBXAccessToken
key in your application’s Info.plist.MGLMapboxAccessToken
is still supported as a deprecated fallback. - The
Incident.impact
property is now anIncident.Impact
value instead of a string. -
RouteOptions.alleyPriority
,RouteOptions.walkwayPriority
, andRouteOptions.speed
are now optional. Set them explicitly if you want to include them in the HTTP request. RenamedDirectionsOptions.default
toDirectionsOptions.medium
. - Removed the
DirectionsResult.routeIdentifier
property. Use theRouteResponse.identifier
property in conjunction with an index into theRouteResponse.routes
array instead.
- The preferred way to set your Mapbox access token is to set the
MBXAccessToken
key in your application’s Info.plist.MGLMapboxAccessToken
is still supported as a deprecated fallback.
Mapbox Maps SDK v10 introduces 3D terrain, improves performance, and upgrades from OpenGL to Metal. Please consult the v10 migration guide, which details many changes that likely affect your application’s user interface code.
Other changes:
- The preferred way to set your Mapbox access token is to set the
MBXAccessToken
key in your application’s Info.plist.MGLMapboxAccessToken
is no longer supported.
- MapboxCoreNavigation no longer depends on MapboxAccounts.
- MapboxNavigation now depends on MapboxMaps instead of Mapbox.framework (Mapbox-iOS-SDK pod).
- The
MBXNavigationBillingMethod
Info.plist key is no longer supported.
Symbols renamed or replaced:
- Removed obsoleted
NavigationMapView.navigationMapDelegate
, which was replaced byNavigationMapView.delegate
. - Renamed
NavigationMapView.navigationMapViewDelegate
toNavigationMapView.delegate
. - Renamed
NavigationMapViewController.mapView
toNavigationMapViewController.navigationMapView
. - Removed
NavigationAnnotation
. -
NavigationMapView.updateCourseTracking(location:camera:animated:)
accepts aCameraOptions
as an argument instead of anMGLMapCamera
. - Removed
NavigationMapView.showsUserLocation
, becauseNavigationMapView
no longer inherits fromMGLMapView
.NavigationMapView.mapView
is now exposed as public property instead. - Changed the type of
NavigationViewController.pendingCamera
fromMGLMapCamera
toCameraOptions
. - Renamed the
Constants.MBRouteLineWidthByZoomLevel
variable toConstants.MBRouteLineWidthByZoomLevel
, which now acceptsDouble
for keys and values. - Renamed the
MBCurrentLegAttribute
property toCurrentLegAttribute
. - Renamed the
MBCongestionAttribute
property toCongestionAttribute
. - Renamed
NavigationViewController.mapView
toNavigationViewController.navigationMapView
. - Renamed
NavigationMapView.highlightBuildings(at:in3D:)
toNavigationMapView.highlightBuildings(at:in3D:completion:)
. - Renamed the
NavigationMapView.updateRoute(_:)
method toNavigationMapView.travelAlongRouteLine(to:)
. - Renamed the following waypoint styling delegate methods:
-
NavigationMapViewDelegate.navigationMapView(_:waypointCircleLayerWithIdentifier:source:)
toNavigationMapViewDelegate.navigationMapView(_:waypointCircleLayerWithIdentifier:sourceIdentifier:)
-
NavigationMapViewDelegate.navigationMapView(_:waypointSymbolLayerWithIdentifier:source:)
toNavigationMapViewDelegate.navigationMapView(_:waypointSymbolLayerWithIdentifier:sourceIdentifier:)
-
NavigationViewControllerDelegate.navigationViewController(_:waypointCircleLayerWithIdentifier:source:)
toNavigationViewControllerDelegate.navigationViewController(_:waypointCircleLayerWithIdentifier:sourceIdentifier:)
-
NavigationViewControllerDelegate.navigationViewController(_:waypointSymbolLayerWithIdentifier:source:)
toNavigationViewControllerDelegate.navigationViewController(_:waypointSymbolLayerWithIdentifier:sourceIdentifier:)
-
Symbols renamed or replaced:
- Renamed
PassiveLocationManager
toPassiveLocationProvider
andPassiveLocationDataSource
toPassiveLocationManager
for consistency withNavigationLocationProvider
andNavigationLocationManager
. -
PassiveLocationProvider
now conforms toLocationProvider
protocol instead ofMGLLocationManager
. - Changed the type of the
PassiveLocationProvider.delegate
property fromMGLLocationManagerDelegate
toLocationProviderDelegate
. - Replaced the
PassiveLocationProvider.accuracyAuthorization()
method with thePassiveLocationProvider.accuracyAuthorization
property, which now returnsCLAccuracyAuthorization
instead ofMBNavigationAccuracyAuthorization
. - Renamed
PassiveLocationManager.startUpdatingLocation(completionHandler:)
toPassiveLocationManager.startUpdatingLocation()
. This method now runs synchronously likeCLLocationManager.startUpdatingLocation()
. - Renamed
RouterDataSource.locationProvider
andActiveNavigationEventsManagerDataSource.locationProvider
properties toRouterDataSource.locationManagerType
andActiveNavigationEventsManagerDataSource.locationManagerType
respectively.
Symbols renamed or replaced:
- Removed the deprecated
CarPlayNavigationDelegate.carPlayNavigationViewControllerDidArrive(_:)
method. - Renamed
CarPlayManager.mapView
toCarPlayManager.navigationMapView
. - Removed the deprecated
CarPlayManager.overviewButton
property. - Removed the unused
CarPlayNavigationViewController.drivingSide
property. - Renamed
CarPlayNavigationDelegate
toCarPlayNavigationViewControllerDelegate
andCarPlayNavigationViewController.carPlayNavigationDelegate
toCarPlayNavigationViewController.delegate
. - Moved
CarPlaySearchController.searchTemplate(_:updatedSearchText:completionHandler:)
,CarPlaySearchController.searchTemplate(_:searchTemplate:selectedResult:completionHandler:)
methods toCarPlaySearchControllerDelegate
protocol; RenamedresultsOrNoResults(_:limit:)
tosearchResults(with:limit:)
. - Moved
GeocodedPlacemark
extension fromCarPlaySearchController
to the application level. RemovedGeocodedPlacemark.listItem()
. -
CarPlayManagerDelegate.carplayManagerShouldDisableIdleTimer(_:)
was renamed toCarPlayManagerDelegate.carPlayManagerShouldDisableIdleTimer(_:)
.
Symbols renamed or replaced:
- Removed the deprecated
InstructionsBannerViewDelegate.didDragInstructionsBanner(_:)
method. - Removed the unused
NavigationViewController.origin
property. -
NavigationViewController.indexedRoute
,NavigationService.indexedRoute
andRouter.indexedRoute
properties are readonly now. Use dedicatedRouter.updateRoute(with:routeOptions:)
method to update the route. - Removed the
NavigationViewController.indexedRoute
,NavigationService.indexedRoute
,Router.indexedRoute
properties in favor ofNavigationViewController.indexedRouteResponse
,NavigationService.indexedRouteResponse
, andRouter.indexedRouteResponse
. Removed theRouteProgress.indexedRoute
property. AddedNavigationViewController.prepareViewLoading(routeResponse:, routeIndex:, routeOptions:, navigationOptions:)
method to setup it forUIStoryboard
. - Renamed
RouteOptions.without(waypoint:)
toRouteOptions.without(_:)
. - Renamed
FeedbackType
toActiveNavigationFeedbackType
andEventsManagerDataSource
toActiveNavigationEventsManagerDataSource
.
Tiles cache cleanup:
When migrating please ensure you have cleaned up old navigation tiles cache folder to reclaim disk space.
- Navigation SDK 2.0 caches navigation tiles in a default folder under
<APP_FOLDER>/Library/Caches/<APP_BUNDLE_ID>/tiles
. - Previous versions of Nav SDK used to cache tiles under a default folder
<APP_FOLDER>/Library/Caches/<APP_BUNDLE_ID>/.mapbox
. - Old cache is not compatible with a new version of SDK 2.0.
- It makes sense to delete any folders used previously for caching including a default one.
-
NavigationSettings.shared.tileStoreConfiguration
enables you to specify a path where nav and map tiles will be saved and if a custom directory was used, it should be cleared as well. - Be sure to configure the custom path before starting a free drive or an active guidance session if you don't want the defaults.
-
If you have any questions, please contact Mapbox’s support team.
Switching from discrete framework bundles to XCFrameworks requires a few changes to your project. Follow these migration steps to switch:
- Delete your
Carthage
folder to remove any existing framework bundles. - Build new XCFrameworks by running
carthage bootstrap --platform iOS --use-xcframeworks --use-netrc
. - Remove references to the old frameworks in each of your targets:
- Delete references to Carthage frameworks from the target's Frameworks, Libraries, and Embedded Content section and/or its Link Binary with Libraries build phase.
- Delete references to Carthage frameworks from any Copy Files build phases.
- Delete the target's
carthage copy-frameworks
build phase, if present.
- Add references to XCFrameworks in each of your targets:
- For an application target: In the General settings tab, in the Frameworks, Libraries, and Embedded Content section, drag and drop each XCFramework you use from the [Carthage/Build][] folder on disk.
- For a framework target: In the Build Phases tab, in a Link Binary with Libraries phase, drag and drop each XCFramework you use from the [Carthage/Build][] folder on disk.