AI-generated Key Takeaways
- 
          GMSNavigatoris the primary class for Google Navigation SDK on iOS, handling navigation, routes, and progress updates, and should be used on the main thread.
- 
          Developers can manage destinations, routes, and guidance settings, including route preferences like avoiding tolls or highways. 
- 
          The GMSNavigatorclass provides properties to control aspects like voice guidance, audio output, vibrations, and background notifications.
- 
          traveledPathstores the user's route, andsetTransactionIDsis for Mobility Services customers to manage billable transactions.
GMSNavigator
@interface GMSNavigator : NSObjectThis is the main class of the Google Navigation SDK for iOS and provides methods for controlling navigation to a destination and accessing route and progress information.
This class does not support subclassing.
This class is not thread-safe. All methods must be called from the main thread.
- 
                  
                  Unavailable DeclarationObjective-C - (instancetype)init NS_UNAVAILABLE;
- 
                  
                  Adds a listener. The listener is held with a weak reference. DeclarationSwift func add(_ listener: any GMSNavigatorListener)Objective-C - (void)addListener:(nonnull id<GMSNavigatorListener>)listener;ParameterslistenerAn object conforming to the GMSNavigatorListenerprotocol.
- 
                  
                  Removes a listener. DeclarationSwift func remove(_ listener: any GMSNavigatorListener) -> BoolObjective-C - (BOOL)removeListener:(nonnull id<GMSNavigatorListener>)listener;ParameterslistenerAn object conforming to the GMSNavigatorListenerprotocol.Return ValueReturns YES if the listener was removed. Returns NO if the object was not a listener. 
- 
                  
                  Sets multiple destinations for navigation, overriding any previously set destinations. The provided callback will be called with GMSRouteStatusOKif a route is found from the device’s location to the given destination. If a new destination is set before a route is found, then the request will be canceled, and the callback will be called withGMSRouteStatusCanceled. If a route cannot be found for any other reason, the callback will be called with an appropriate error status.Note When navigating a route with multiple waypoints, it is the application’s responsibility to notice arrival at each waypoint, either by listening to -navigator:didArriveAtWaypoint:or by independently verifying arrival; and to then update the destinations, either by calling one of the-setDestinations:...methods or by calling-continueToNextDestination. Also, ifstopGuidanceAtArrivalis set toYES, the application will need to start guidance again after updating the destinations.Note Calls to -setDestinations:callback:clear the traveled path.DeclarationSwift func setDestinations(_ destinations: [GMSNavigationWaypoint], callback: @escaping GMSRouteStatusCallback)Objective-C - (void)setDestinations:(nonnull NSArray<GMSNavigationWaypoint *> *)destinations callback:(nonnull GMSRouteStatusCallback)callback;ParametersdestinationsAn array of destination waypoints. callbackCalled asynchronously on the main queue when a route from the consumer’s location to the provided destination(s) is found, or fails to be found for a reason indicated by the RouteStatus. 
- 
                  
                  Sets multiple destinations for navigation, overriding any previously set destinations. The returned routes are calculated using routing options. Note Calls to -setDestinations:routingOptions:callback:clear the traveled path.DeclarationSwift func setDestinations(_ destinations: [GMSNavigationWaypoint], routingOptions: GMSNavigationRoutingOptions, callback: @escaping GMSRouteStatusCallback)Objective-C - (void)setDestinations:(nonnull NSArray<GMSNavigationWaypoint *> *)destinations routingOptions:(nonnull GMSNavigationRoutingOptions *)routingOptions callback:(nonnull GMSRouteStatusCallback)callback;ParametersdestinationsAn array of destination waypoints. routingOptionsThe options that influence routing logic (routing strategy). callbackCalled asynchronously on the main queue when a route from the consumer’s location to the provided destination(s) is found, or fails to be found for a reason indicated by the RouteStatus. 
- 
                  
                  Sets multiple destinations for navigation, using a route token to navigate on a precomputed route. Routes will be the same, modulo changes to the driver starting location and to road/traffic conditions. Re-routes will still occur based on the routing options encoded in the token. Only GMSNavigationTravelModeDrivingandGMSNavigationTravelModeTwoWheelerare supported when you use the route token to start a navigation session. Configure the travel mode by settingtravelMode.The call will fail if the current travel mode is unsupported, and aGMSRouteStatusTravelModeUnsupportedwill be returned in the callback.Note Calls to -setDestinations:routeToken:callback:clear the traveled path.DeclarationSwift func setDestinations(_ destinations: [GMSNavigationWaypoint], routeToken: String, callback: @escaping GMSRouteStatusCallback)Objective-C - (void)setDestinations:(nonnull NSArray<GMSNavigationWaypoint *> *)destinations routeToken:(nonnull NSString *)routeToken callback:(nonnull GMSRouteStatusCallback)callback;ParametersdestinationsAn array of destination waypoints, should be the same as the destinations given to RoutesPreferred API to get the route token. routeTokenA route token string returned by RoutesPreferred API. Routing options specified in RoutesPreferred API are encoded in this route token, and will be used to regenerate the precomputed route or a new route when reroute happens. callbackCalled asynchronously on the main queue when a route from the consumer’s location to the provided destination(s) is found, or fails to be found for a reason indicated by the RouteStatus. 
- 
                  
                  Returns route information based on the routing strategy: default best or shorter route. This method is only available to Mobility Services customers who are billed by Google on a per-transaction basis. Returns a nilvalue if the project lacks permission to call this API.DeclarationSwift func getRouteInfo(forDestination destination: GMSNavigationWaypoint, with routingOptions: GMSNavigationRoutingOptions, callback: @escaping GMSRouteInfoCallback)Objective-C - (void)getRouteInfoForDestination:(nonnull GMSNavigationWaypoint *)destination withRoutingOptions: (nonnull GMSNavigationRoutingOptions *)routingOptions callback:(nonnull GMSRouteInfoCallback)callback;ParametersdestinationThe destination waypoint. routingOptionsThe options used to fetch the route info. The routing strategy and alternate routes strategy are ignored since this method returns the route information for all routing strategies. callbackThe callback called when routes information are received. 
- 
                  
                  Deprecated Use one of the -setDestinations:… methods instead. Deprecated. Call one of the -setDestinations:...methods with the new list of destinations instead.Pops the first destination from the current list of destinations. Following this call, guidance will be toward the next destination, if any. Note Calls to -continueToNextDestinationclear the traveled path.DeclarationSwift func continueToNextDestination() -> GMSNavigationWaypoint?Objective-C - (nullable GMSNavigationWaypoint *)continueToNextDestination;Return Valuethe waypoint guidance is now heading towards, or nil if there are no more waypoints left. 
- 
                  
                  Clears all previously set destinations and removes any calculated routes from the map. If guidance is active, this will automatically stop it. DeclarationSwift func clearDestinations()Objective-C - (void)clearDestinations;
- 
                  
                  Whether to avoid highways when generating routes to destinations. Defaults to NO. DeclarationSwift var avoidsHighways: Bool { get set }Objective-C @property (nonatomic) BOOL avoidsHighways;
- 
                  
                  Whether to avoid toll roads when generating routes to destinations. Defaults to NO. DeclarationSwift var avoidsTolls: Bool { get set }Objective-C @property (nonatomic) BOOL avoidsTolls;
- 
                  
                  Whether to avoid ferries when generating routes to destinations. Defaults to YES. DeclarationSwift var avoidsFerries: Bool { get set }Objective-C @property (nonatomic) BOOL avoidsFerries;
- 
                  
                  Set license plate restriction with current driver’s last digit of license plate and country code. This allows us to route around certain types of road restrictions which are based on license plate number. This will only apply to setDestinations calls made after this value is set. Ideally you’d set this immediately after getting the navigator. Set to nil if there is no license plate restriction. Default to nil. DeclarationSwift var licensePlateRestriction: GMSNavigationLicensePlateRestriction? { get set }Objective-C @property (nonatomic, nullable) GMSNavigationLicensePlateRestriction *licensePlateRestriction;
- 
                  
                  Whether turn-by-turn guidance is currently enabled. If guidanceActive is YES, but no route is currently available then guidance will start when a route becomes available. This property will be set to NO if clearDestinations is called, or we arrive at a waypoint. DeclarationSwift var isGuidanceActive: Bool { get set }Objective-C @property (nonatomic, assign, unsafe_unretained, readwrite, getter=isGuidanceActive) BOOL guidanceActive;
- 
                  
                  Whether guidance should automatically stop when -navigator:didArriveAtWaypoint:is called.When NO, the navigation header and footer will continue to be shown after arrival. The navigation header will continue to show the final guidance step and the navigation footer will continue to update the remaining time and distance until a time/distance of 0 is reached. Additionally, -navigator:didUpdateRemainingTimeand-navigator:didUpdateRemainingDistanceupdates will continue. Explicitly setguidanceActiveto NO to stop guidance and remaining time/distance updates.When YES, guidanceActivewill automatically be set to NO upon arrival.Defaults to YES. DeclarationSwift var stopGuidanceAtArrival: Bool { get set }Objective-C @property (nonatomic) BOOL stopGuidanceAtArrival;
- 
                  
                  The minimum change in estimated time to the next destination that will trigger the -navigator:didUpdateRemainingTime:method to be called.If this is set to NSTimeIntervalMax, then time update callbacks will be disabled. If this is set to a negative value, then the default threshold of one second will be used. Defaults to one second.Note This value is ignored if no listeners implementnavigator:didUpdateRemainingTime:.DeclarationSwift var timeUpdateThreshold: TimeInterval { get set }Objective-C @property (nonatomic) NSTimeInterval timeUpdateThreshold;
- 
                  
                  The minimum change in estimated distance to the next destination that will trigger the -navigator:didUpdateRemainingDistance:method to be called.If this is set to CLLocationDistanceMax, then distance update callbacks will be disabled. If this is set to a negative value, then the default threshold of one meter will be used. Defaults to one meter.Note This value is ignored if no listeners implementnavigator:didUpdateRemainingDistance:.DeclarationSwift var distanceUpdateThreshold: CLLocationDistance { get set }Objective-C @property (nonatomic) CLLocationDistance distanceUpdateThreshold;
- 
                  
                  Returns the estimated time to the next destination. This will be updated based on the current device position whilst guidance is active. DeclarationSwift var timeToNextDestination: TimeInterval { get }Objective-C @property (nonatomic, readonly) NSTimeInterval timeToNextDestination;Return ValueCLTimeIntervalMaxif no route is available.
- 
                  
                  Returns the estimated distance to the next destination. This will be updated based on the current device position whilst guidance is active. DeclarationSwift var distanceToNextDestination: CLLocationDistance { get }Objective-C @property (nonatomic, readonly) CLLocationDistance distanceToNextDestination;Return ValueCLLocationDistanceMaxif no route is available.
- 
                  
                  Returns the delay category to the next destination. This will be updated based on the current device position whilst guidance is active. DeclarationSwift var delayCategoryToNextDestination: GMSNavigationDelayCategory { get }Objective-C @property (nonatomic, readonly) GMSNavigationDelayCategory delayCategoryToNextDestination;Return ValueGMSNavigationDelayCategoryNoDataif no route is available or traffic data is unavailable.
- 
                  
                  Returns the estimated time to the given waypoint, or CLTimeIntervalMaxif the waypoint is not part of the current route. This is updated based on the current device position while guidance is active.DeclarationSwift func time(to waypoint: GMSNavigationWaypoint) -> TimeIntervalObjective-C - (NSTimeInterval)timeToWaypoint:(nonnull GMSNavigationWaypoint *)waypoint;Return ValueCLTimeIntervalMaxif the provided waypoint is not a destination in the current route.
- 
                  
                  Returns the estimated distance to the given waypoint, or CLLocationDistanceMax if the waypoint is not part of the current route. This will be updated based on the current device position whilst guidance is active. DeclarationSwift func distance(to waypoint: GMSNavigationWaypoint) -> CLLocationDistanceObjective-C - (CLLocationDistance)distanceToWaypoint: (nonnull GMSNavigationWaypoint *)waypoint;Return ValueCLLocationDistanceMaxif the provided waypoint is not a destination in the current route.
- 
                  
                  The current leg of the journey. This GMSRouteLegwill have its starting position as the most recent known (road-snapped) position of the device.DeclarationSwift var currentRouteLeg: GMSRouteLeg? { get }Objective-C @property (nonatomic, readonly, nullable) GMSRouteLeg *currentRouteLeg;
- 
                  
                  An array of route legs where each leg corresponds to a destination that was set. DeclarationSwift var routeLegs: [GMSRouteLeg]? { get }Objective-C @property (nonatomic, readonly, nullable) NSArray<GMSRouteLeg *> *routeLegs;
- 
                  
                  The path that the user has traveled in the most recent guidance session, defined as the last time guidanceActive was set to YES. The path consists of road-snapped locations returned by the GMSRoadSnappedLocationProviderand simplified to produce line segments. Note: The system polls the client for GPS signals to obtain location data. Poor GPS signal can result in further interpolation, which might produce less precise routes. This path is empty if guidance has never started.
- 
                  
                  Determines whether voice guidance should be enabled for traffic and turn-by-turn alerts. Defaults to GMSNavigationVoiceGuidanceAlertsAndGuidance.DeclarationSwift var voiceGuidance: GMSNavigationVoiceGuidance { get set }Objective-C @property (nonatomic) GMSNavigationVoiceGuidance voiceGuidance;
- 
                  
                  Determines what audio devices voice guidance may be played through. Defaults to GMSVoiceGuidanceAudioDeviceTypeBluetooth.DeclarationSwift var audioDeviceType: GMSVoiceGuidanceAudioDeviceType { get set }Objective-C @property (nonatomic) GMSVoiceGuidanceAudioDeviceType audioDeviceType;
- 
                  
                  Determines whether the device should also vibrate when voice alerts are played. DeclarationSwift var isVibrationEnabled: Bool { get set }Objective-C @property (nonatomic, assign, unsafe_unretained, readwrite, getter=isVibrationEnabled) BOOL vibrationEnabled;
- 
                  
                  Determines whether UILocalNotifications containing guidance information will be presented when the app is in the background. Defaults to YES. DeclarationSwift var sendsBackgroundNotifications: Bool { get set }Objective-C @property (nonatomic) BOOL sendsBackgroundNotifications;
- 
                  
                  The suggested lighting mode, based on the time of day and device location. DeclarationSwift var suggestedLightingMode: GMSNavigationLightingMode { get }Objective-C @property (nonatomic, readonly) GMSNavigationLightingMode suggestedLightingMode;
- 
                  
                  Determines whether prompts for traffic, better routes and incidents should be displayed. Defaults to YES. DeclarationSwift var shouldDisplayPrompts: Bool { get set }Objective-C @property (nonatomic) BOOL shouldDisplayPrompts;
- 
                  
                  GMSNavigationSpeedAlertOptionsfor customizing the triggering thresholds forGMSNavigationSpeedAlertSeverity.You can use this property to customize the speed alert triggering thresholds in percentage for both minor and major alerts. You can also use this method to customize the time based triggering threshold for major speed alert. By setting nil, you won’t receive any speeding feed data, and the NavSDK’s default speed alert will display: speed alert shows red text when the speed is more than 5 mph or 10 kph over the speed limit, and shows white text and red background when speeding more than 10 mph or 20kph. DeclarationSwift var speedAlertOptions: GMSNavigationSpeedAlertOptions? { get set }Objective-C @property (nonatomic, nullable) GMSNavigationSpeedAlertOptions *speedAlertOptions;
- 
                  
                  Sets and logs to the server the ongoing transaction IDs that apply to the navigation events during the current navigation session. Transaction IDs will be cleared at the end of the navigation session. This method is only available to Mobility Services customers who are billed by Google on a per-transaction basis. Returns a nilvalue if the project lacks permission to call this API.DeclarationSwift func setTransactionIDs(_ transactionIDs: [String], errorHandler: GMSNavigationTransactionIDErrorHandler? = nil)Objective-C - (void)setTransactionIDs:(nonnull NSArray<NSString *> *)transactionIDs errorHandler: (nullable GMSNavigationTransactionIDErrorHandler)errorHandler;ParameterstransactionIDsThe transaction IDs that apply to the current navigation session. The transaction ID must be unique for each billable transaction. An individual transaction ID must contain at least one and at most 64 characters. The list can be empty when a transaction has ended (but the session is still ongoing). errorHandlerA block that will be invoked asynchronously on the main thread if an error occurs when the transaction IDs are invalid.