TomTomNavigation
public protocol TomTomNavigation : AnyObject
The TomTomNavigation protocol defines the functionality of the navigation.
Important
This is a Public Preview API. It may be changed or removed at any time.-
Provides access to current registered engines and allows updating them.
Declaration
Swift
var navigationEngineRegistry: NavigationEngineRegistry { get set } -
The
VehicleProviderused by theTomTomNavigationfor providing vehicle updates to the navigation.Declaration
Swift
var vehicleProvider: VehicleProvider { get } -
Provides a
CLLocationfor map matching.Declaration
Swift
var mapMatchedLocationProvider: LocationProvider { get } -
Provides a
CLLocationfor raw GPS position.Declaration
Swift
var locationProvider: LocationProvider { get set } -
The unit system used by the SDK.
Propagated to other components (e.g.,
GuidanceEngine) withNavigationSnapshot.If the
UnitSystemTypeinstance is dynamic, then unit system is resolved based on current location country:- “USA” and “PRI” -
SpecificUnitSystem/imperialFeet. - “GBR” -
SpecificUnitSystem/imperialYards. - Other countries -
SpecificUnitSystem/metric.
Declaration
Swift
var unitSystem: UnitSystemType { get set } - “USA” and “PRI” -
-
The language used by Navigation SDK, stored as a Locale. Propagated to other components (e.g.
GuidanceEngine) withNavigationSnapshot.Note
Defaults to current system locale.Declaration
Swift
var language: Locale { get set } -
A publishable variable that can be used to receive the same events that the delegate presents
Declaration
Swift
var eventPublisher: AnyPublisher<NavigationEvent, Never> { get } -
start()Default implementationStarts navigation with the default routing.
Default Implementation
Starts navigation with the default routing.
Declaration
Swift
func start() -
start(navigationOptions:Default implementation) Starts navigation with a navigation plan.
Warning
NavigationOptions.alternativeRoutePlans is not used as multi-route navigation is not supported.Default Implementation
Starts navigation with a navigation plan.
Warning
NavigationOptions.alternativeRoutePlans is not used as multi-route navigation is not supported.Declaration
Swift
func start(navigationOptions: NavigationOptions)Parameters
navigationOptionsNavigationOptionsto be used during the navigation session. -
update(navigationOptions:Default implementation) Updates the route plan during ongoing navigation.
Default Implementation
Updates the route plan during ongoing navigation.
Declaration
Swift
func update(navigationOptions: NavigationOptions)Parameters
navigationOptionsNavigationOptionsto be used during the navigation session. -
Accept the better route proposed and update the route plan during navigation.
Declaration
Swift
func acceptBetterProposal() -
Manually marks the waypoint as visited. This action requires that waypoint was previously announced as reached via
NavigationArrivalObserverand that it has not been announced as visited viaNavigationArrivalObserver. The navigation service marks the waypoint as visited, andNavigationArrivalObserveris notified.Throws
NavigationProcessingError.nextWaypointErrorif calling requirements are not met.Declaration
Swift
func markWaypointAsVisited(waypoint: RouteStop) throwsParameters
waypointThe waypoint to mark as visited.
-
Stops the current navigation.
Declaration
Swift
func stop() -
Adds a
NavigationObservertoTomTomNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addNavigationObserver(_ observer: NavigationObserver)Parameters
observerA class that can handle all navigation events except for error events.
-
Removes the
NavigationObserverfromTomTomNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeNavigationObserver(_ observer: NavigationObserver)Parameters
observerA class that can handle all navigation events except for error events.
-
Adds a
NavigationStartObservertoTomTomNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addStartObserver(_ observer: NavigationStartObserver)Parameters
observerA class that can handle navigation start events.
-
Removes the
NavigationStartObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeStartObserver(_ observer: NavigationStartObserver)Parameters
observerA class that can handle navigation start events.
-
Adds a
NavigationMapMatchingObservertoNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addMapMatchingObserver(_ observer: NavigationMapMatchingObserver)Parameters
observerA class that can handle navigation map matching events.
-
Removes the
NavigationMapMatchingObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeMapMatchingObserver(_ observer: NavigationMapMatchingObserver)Parameters
observerA class that can handle navigation map matching events.
-
Adds a
NavigationProgressObservertoNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addProgressObserver(_ observer: NavigationProgressObserver)Parameters
observerA class that can handle navigation start events.
-
Removes the
NavigationProgressObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeProgressObserver(_ observer: NavigationProgressObserver)Parameters
observerA class that can handle navigation progress events.
-
Adds a
NavigationRouteObservertoNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addRouteObserver(_ observer: NavigationRouteObserver)Parameters
observerA class that can handle navigation route events.
-
Removes the
NavigationRouteObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeRouteObserver(_ observer: NavigationRouteObserver)Parameters
observerA class that can handle navigation route events.
-
Adds a
NavigationGuidanceObservertoNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addGuidanceObserver(_ observer: NavigationGuidanceObserver)Parameters
observerA class that can handle navigation guidance events.
-
Removes the
NavigationGuidanceObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeGuidanceObserver(_ observer: NavigationGuidanceObserver)Parameters
observerA class that can handle navigation guidance events.
-
Adds a
NavigationLocationContextObservertoNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addLocationContextObserver(_ observer: NavigationLocationContextObserver)Parameters
observerA class that can handle navigation location context events.
-
Removes the
NavigationLocationContextObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeLocationContextObserver(_ observer: NavigationLocationContextObserver)Parameters
observerA class that can handle navigation location context events.
-
Adds a
NavigationArrivalObservertoNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addArrivalObserver(_ observer: NavigationArrivalObserver)Parameters
observerA class that can handle navigation arrival events.
-
Removes the
NavigationArrivalObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeArrivalObserver(_ observer: NavigationArrivalObserver)Parameters
observerA class that can handle navigation arrival events.
-
Adds a
NavigationHorizonObservertoNavigation. It is expected to be called on the main queue.Throws
HorizonError.observerAlreadyRegisteredif thisNavigationHorizonObserverobject is already registered for horizon updates.HorizonError.optionsAlreadyRegisteredif theseHorizonOptionsare already being observed.Declaration
Swift
func addHorizonObserver(_ observer: NavigationHorizonObserver, options: HorizonOptions) throwsParameters
observerA class that can handle navigation horizon events. To register a new observer with the same options, the previous one must be removed first. To register different options with the same observer, the previous one must be removed first.
optionsThe options that define the extent of the paths on the horizon and which map attributes to collect.
-
Removes the
NavigationHorizonObserverfromNavigation. This method should be called on the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeHorizonObserver(_ observer: NavigationHorizonObserver) throwsParameters
observerA class that can handle navigation trip events.
-
Adds a
NavigationRouteTrackingStateUpdateObservertoNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Important
This is a Public Preview API. It may be changed or removed at any time.Declaration
Swift
func addRouteTrackingStateUpdateObserver(_ observer: NavigationRouteTrackingStateUpdateObserver)Parameters
observerA class that can handle navigation follow the route events.
-
Removes the
NavigationRouteTrackingStateUpdateObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Important
This is a Public Preview API. It may be changed or removed at any time.Declaration
Swift
func removeRouteTrackingStateUpdateObserver(_ observer: NavigationRouteTrackingStateUpdateObserver)Parameters
observerA class that can handle navigation follow the route events.
-
Adds a
NavigationErrorObservertoNavigation. Keeps a weak pointer to the observer. It is expected to be called on the main queue.Declaration
Swift
func addErrorObserver(_ observer: NavigationErrorObserver)Parameters
observerA class that can handle navigation error events.
-
Removes the
NavigationErrorObserverfromNavigation. There is no need to call this function from the deinit of the observer. It is expected to be called on the main queue.Declaration
Swift
func removeErrorObserver(_ observer: NavigationErrorObserver)Parameters
observerA class that can handle navigation error events.
TomTomNavigation Protocol Reference