Google Navigation SDK standalone

The Google Navigation SDK delivers the familiar Google Maps turn by turn directions experience as a standalone software package, allowing you to integrate and customize a navigation module within your own mobile app. Finally, one of Google Maps's most requested features is now available to everyone as a ready to use solution that can be implemented with just a few lines of code. In this blog post, we’ll break down how the Navigation SDK (Nav SDK) works, what it costs, who it’s for, and how you can get it up and running in no time at all.

How in-app turn by turn navigation with the Google Maps Navigation SDK looks like

Part 1: Google Navigation SDK standalone (this article)
Part 2: Getting started with the Google Navigation SDK
Part 3: Adding a Place Autocomplete text box to your Android app
Part 4: Creating a custom route on Google Maps for Android with the Routes API
Part 5: Styling the Navigation SDK with custom UI and branding
Part 6: Custom Google Maps markers on the navigation view
Part 7: Customize your vehicle icon with the Navigation SDK
Part 8: Custom polygons, boundaries and base map styles in the Navigation SDK
Part 9: Using the Navigation SDK for multi waypoint navigation
Part 10: Passing a GMPRO or Routes API route token to the Navigation SDK
Part 11: Listening for events and detecting arrival at destination
Part 12: Google Navigation SDK vs Mapbox vs HERE Maps

Introducing the Google Navigation SDK

If you drive, chances are you’ve used the turn-by-turn navigation feature in the Google Maps app at least once before. You search for a destination or enter an address, review the route, hit the start button and get on your way.

Google Maps consumer app in-app turn by turn navigation

The Google Navigation SDK lets you do all of this directly in your app. It delivers the trusted Google Maps navigation experience while allowing for complete customization over the user interface and driver experience, ensuring it aligns perfectly with your brand and business goals.

⚠️
Truck and heavy vehicle routing are not supported by the Google Nav SDK (yet). Try using HERE Maps instead.

The Nav SDK should prove useful to any company or business operation that has a "driver app". It is particularly well-suited for last mile delivery providers like FedEx, UPS, and other parcel delivery services, as well as ride-sharing platforms such as Uber and Lyft. It can also benefit field service companies, like cable providers scheduling technicians for installations, or even non-emergency medical transport services. It's the perfect fit for any company with dedicated driver fleets, where accurate and dependable navigation is essential for operational success.

Why use the Google Navigation SDK?

Aside from customization, the main benefit of the Nav SDK is that it can show your users how to get from point A to B safely and accurately, without leaving your app. There are four main components to this:

Location tracking

The Nav SDK lets users keep your app in the foreground (the first app that loads when you unlock your phone) so that you can track the location of your drivers in real time. Using a third-party turn-by-turn navigation app pushes your app into the background, stopping location tracking and making it cumbersome to deal with real time updates and notifications.

Driver safety

Drivers can navigate directly within your app, eliminating the need to switch to external apps like Google Maps, Waze, or Apple Maps. This helps them stay focused on the road and reduces distractions.

Real time traffic

The Nav SDK also uses the same real time traffic information that powers the consumer Google Maps app, so traffic conditions and ETAs (Estimated Time of Arrival) are very accurate. This feature helps drivers navigate around traffic congestion and select the quickest route to their destination. If a driver misses a turn or gets lost, the Nav SDK automatically recalculates a new route to guide them back on track.

Consistency across Google Maps APIs

The Nav SDK provides the option to pass a route token instead of specifying origin and destination waypoints. This enables you to generate a route using a different Google Maps API, such as the Routes API or GMPRO, based on business-critical metrics such as lowest cost, avoid tolls, or side of road preference. Once the route is created, you can pass it to the Nav SDK to make it clear to your drivers that they are supposed to follow the exact path you’ve defined. Additionally, any deviations from the route can be detected and tracked using the RouteChangedListener, allowing for detailed logging and analysis as needed.

How does the Google Navigation SDK work?

The Nav SDK lives inside your app as a self contained module that holds a 3D version of Google Maps. When you pass the Nav SDK an origin (typically the user's current location) and a destination, it retrieves the route polyline and driving directions from the Routes API (this is handled internally by the Nav SDK and you are not charged separately for it) and displays it on the map as a blue line. As you drive, the Nav SDK dynamically updates your location on the map and adjusts the route to reflect your progress, effectively shortening the remaining distance in real time.

When you deviate from the original route, for example if you miss a turn, it calls the Routes API again and recalculates a new one. If a route with a similar ETA is available, it is shown as a grayed out polyline on the map, and following this new route automatically turns it blue.

Customization options with the Google Navigation SDK

The Nav SDK's customization capabilities allow you to create a navigation experience that is both intuitive and consistent with your brand identity. Key user interface (UI) elements you can customize with the Nav SDK include:

A partial list of customizable features in the Google Navigation SDK

Turn cards: Modify the text and color of upcoming turns and directions, to match your app's design.

Map UI controls: Determine which built-in controls and elements appear on the map, such as zoom buttons, compass, and user location indicators.

Navigation header: Adjust the visual appearance of the navigation header, including background colors, text elements, and maneuver icons, to ensure consistency with your app's theme.

Traffic lights and stop signs: Toggle traffic lights and stop sign icons on or off.

Lane guidance indicators: Customize the color and style of lane guidance indicators to improve clarity and user comprehension during navigation.

Custom controls: Add custom UI elements at predefined positions on the navigation view, such as secondary headers, footers, or overlays, to provide additional information or functionality.

💡
A partial list of of customizable Nav SDK user interface elements can be found at the official documentation.

It is probably easier to list down what can't be customized:

  • Route polyline. You can turn real time traffic on the polyline on or off, but you can't change its color or style.

Please message me on LinkedIn if you find a component that you want to customize, but can't.

Google Navigation SDK Pricing

The Google Navigation SDK uses a pay-as-you-go pricing model consistent with other Google Maps Platform services. Customers are billed based on the number of destinations sent to the SDK. The first 1,000 destinations each month are free, and beyond that, the cost per 1,000 destinations (CPM) depends on the total monthly volume.

Monthly destinations Cost per 1,000 destinations
Up to 1,000 Free
1,000 to 4.2 mil $50.00 CPM
4.2 mil to 16.8 mil $39.50 CPM
16.8 mil to 84 mil $28.00 CPM
84 mil + $20.00 CPM

The starting price of $50 CPM ($0.05 per destination) might seem high, but its comparable to the Mapbox Navigation SDK and there are no additional charges for route changes after a destination has already been fetched. For example, you don't pay extra if you miss a turn and the Nav SDK recalculates the route for you. Furthermore, there are no additional fees for using the Google base map within the SDK.

Obviously, $50 CPM (or $0.05 per destination) is not for everyone. Most logistics businesses in the US try and keep third party API costs under $0.10 per delivery, so $0.05 takes up half their budget. It's also not a good fit for automative or device manufacturers that want to bundle the Nav SDK for free (like Tesla does), because Google does not offer per device pricing (unless you're Elon Musk).

💡
If you are a heavy Google Maps Platform user, consider switching to Google Mobility. This service combines multiple Nav SDK and other Google Maps API calls into a single, per-trip pricing model.

If you are dealing with high usage volumes, you can work with a Google Maps partner for volume discounts. See the official pricing page for details.

How to set up the Google Navigation SDK

To start using the Nav SDK, the first thing you need to do is set it up it in your Google Cloud console.

Create new Google Cloud project

First, create a new project from the console dashboard at https://console.cloud.google.com/ and name it nav-sdk-proj. Click [CREATE].

Creating a new project on the Google Cloud Console

To enable the Google Navigation SDK, go to the APIs & Services page by selecting it on the left hand menu. Once there, choose [+ Enable APIs and Services] and search for the "Navigation SDK".

Selecting the Navigation SDK from the list of available APIs

Click on the [Navigation SDK] link and press the [Enable] button.

Enabling the Navigation SDK on the Google Cloud Console

Repeat this for "Google Maps SDK for Android" (or iOS, if you are developing an iPhone app) because we'll need to give the Nav SDK access to the Google base map.

Enabling the Maps SDK for Android in the Google Cloud Console

Next, while still in the nav-sdk-proj project, use the left hand navigation bar to head to the Credentials page. Click on the [+ Create Credentials] button and choose the [API Key] option. On the next page, use the drop down menu to make sure that Navigation SDK and Google Maps SDK for Android are both enabled.

Check to see the required APIs are enabled in your Google Cloud project

Click [Save]. If you return to the Keys and Credentials page, you can find your new API key by clicking the [Show Key] link on the right.

Retrieving the Google Navigation SDK API key for use in your app

How to run the Google Navigation SDK in Android

Getting the Nav SDK up and running takes more than just adding a few lines of code (see our Google Navigation SDK tutorial for a detailed walkthrough), but here's a quick overview of what it takes to integrate it into an Android app.

First, ensure you have Google Play Services and Maps SDK enabled by listing it as a dependency in the build.gradle.kts file.

api("com.google.android.libraries.navigation:navigation:5.2.3")

Second in AndroidManifest.xml, allow your app to access location services while running in a foreground service.

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.FOREGROUND_SERVICE_LOCATION" />

Third, import the required libraries into your MainActivity.kt file.

import com.google.android.libraries.navigation.NavigationApi
import com.google.android.libraries.navigation.Navigator
import com.google.android.libraries.navigation.NavigationView
import com.google.android.libraries.places.api.model.Place

Finally, simply execute the startGuidance() command to begin turn by turn navigation.

private var mNavigator = SuspendRef<Navigator>()

val place: Place = Place.builder()
    .setName("685 Pacific Blvd")
    .setAddress("Vancouver, BC, Canada")
    .setLatLng(LatLng(37.8199, -122.4783))
    .build()


val navigator = mNavigator.await()
        val waypoint = getWayPoint(place)
        val pendingRoute = navigator.setDestination(
            waypoint,
            RoutingOptions()
                .travelMode(TravelMode.DRIVING),
            DisplayOptions()
                .showStopSigns(true)
                .showTrafficLights(true)
        )
navigator.startGuidance()

Google Navigation SDK starter code

Google offers extensive documentation and starter code, but you'll still need an engineer experienced in Android, iOS, or cross-platform development (React Native or Flutter) to implement turn by turn navigation in your driver app and get the app approved for distribution in the iOS App Store / Google Play Store.

Platform Github Link
iOS https://github.com/googlemaps/ios-navigation-sdk
Android https://github.com/googlemaps-samples/android-navigation-samples
React Native https://github.com/googlemaps/react-native-navigation-sdk
Flutter https://github.com/googlemaps/flutter-navigation-sdk

As always, feel free to reach out to me if you need help implementing the Nav SDK in your project.

What's next in this Google Navigation SDK tutorial series

The Google Navigation SDK is not just an API, its a set of libraries, documentation, and code samples that allow you to integrate Google Maps turn by turn navigation features directly within your own app.

Although in-app turn by turn navigation has been one of Google Map's most requested features, the success of the Nav SDK is far from certain. Established navigation and mapping companies like Tom TomHERE Maps and Mapbox have been offering similar solutions for years, often with per-device pricing that Google cannot match. Additionally, Google faces competition from its own free turn by turn navigation available in the consumer Google Maps app.

Despite these challenges, I believe the Nav SDK will find its niche and remain an essential component of Google Maps technology that is worth getting comfortable with. Upcoming topics in this tutorial series will include:

Next: Part 2: Getting started with the Google Navigation SDK