Navigation SDK overview
Stay organized with collections
Save and categorize content based on your preferences.
The Navigation SDK lets you to integrate Google Maps turn-by-turn navigation
into your mobile applications. Crucially, it provides
current route segment and final destination data, which, along with location
updates and latitude/longitude coordinates from the Driver SDK, are sent to the
Fleet Engine when your driver begins driving. This results in a complete driving
experience.
Why use the Navigation SDK?
The Navigation SDK enables easier integration with Fleet Engine for updates to
the driver's routes. Using the Navigation SDK along with the Driver SDK enables
your driver can use a single app to manage assignments and navigate as they
would using their consumer version of Google Maps, without having to switch to
another app.
What can you do with the Navigation SDK?
Use the Navigation SDK to communicate the following with Fleet Engine.
- Reliable turn-by-turn navigation instructions powered by Google Maps.
- Customized routes based on the latitude/longitude coordinates provided by the
Driver SDK.
- Customized map elements, such as custom markers, overlays, and UI elements to
highlight key navigation information and to personalize the navigation
experience.
How the Navigation SDK works
The Navigation SDK provides routing information and destination to Fleet Engine,
while the Driver SDK provides a stream of location updates, latitude/longitude
coordinates, remaining distance, and ETAs. All other vehicle data updates must
be sent to the customer backend, which relays the data to Fleet Engine.

How to use the Navigation SDK
The steps below cover a typical use-case scenario for incorporating the
Navigation SDK into your driver application:
Android
1 |
Set up your Google Cloud project |
Create a Google Cloud project before using the Navigation SDK. For more information, see Set up your Google Cloud project. |
2 |
Add the Navigation SDK to your API key |
The API key is a unique identifier that authenticates your requests, associate at least one API key with your project to use the Navigation SDK. For more information, see Using API keys. |
3 |
Set up your Android Studio project |
Create an Android project and integrate the Navigation SDK into it. For more information, see Set up your Android Studio project. |
4 |
Add the Driver SDK to your project |
Install and configure the Driver SDK to start taking advantage of all the Fleet Engine features. For more information, see Get the Driver SDK for on-demand trips and Get the Driver SDK for scheduled tasks. |
iOS
1 |
Set up your Google Cloud project |
Create a Google Cloud project before using the Navigation SDK. For more information, see Set up your Google Cloud project. |
2 |
Add the Navigation SDK to your API key |
The API key is a unique identifier that authenticates your requests, associate at least one API key with your project to use the Navigation SDK. For more information, see Using API keys. |
3 |
Set up your Xcode project |
Create an Xcode project and install the Navigation SDK into it. For more information, see Set up your Xcode project. |
4 |
Add the Driver SDK to your project |
Install and configure the Driver SDK to start taking advantage of all the Fleet Engine features. For more information, see Get the Driver SDK for on-demand trips and Get the Driver SDK for scheduled tasks. |
For more information about the Navigation SDK features, see the complete
documentation for Navigation SDK for
Android and
iOS.
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-08-18 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-18 UTC."],[[["\u003cp\u003eThe Navigation SDK enables turn-by-turn navigation within your mobile apps, seamlessly integrating with Google Maps and Fleet Engine for real-time route and location updates.\u003c/p\u003e\n"],["\u003cp\u003eWhen used with the Driver SDK, it provides a comprehensive driving experience within a single app, eliminating the need for drivers to switch between navigation and task management.\u003c/p\u003e\n"],["\u003cp\u003eThe SDK offers customizable routes, map elements, and navigation instructions powered by Google Maps, ensuring a tailored and efficient navigation experience for drivers.\u003c/p\u003e\n"],["\u003cp\u003eTo utilize the Navigation SDK, developers need to set up a Google Cloud project, integrate the SDK into their Android or iOS project, and add the Driver SDK for comprehensive Fleet Engine functionality.\u003c/p\u003e\n"]]],[],null,["The Navigation SDK lets you to integrate Google Maps turn-by-turn navigation\ninto your mobile applications. Crucially, it provides\ncurrent route segment and final destination data, which, along with location\nupdates and latitude/longitude coordinates from the Driver SDK, are sent to the\nFleet Engine when your driver begins driving. This results in a complete driving\nexperience.\n\nWhy use the Navigation SDK?\n\nThe Navigation SDK enables easier integration with Fleet Engine for updates to\nthe driver's routes. Using the Navigation SDK along with the Driver SDK enables\nyour driver can use a single app to manage assignments and navigate as they\nwould using their consumer version of Google Maps, without having to switch to\nanother app.\n\nWhat can you do with the Navigation SDK?\n\nUse the Navigation SDK to communicate the following with Fleet Engine.\n\n- Reliable turn-by-turn navigation instructions powered by Google Maps.\n- Customized routes based on the latitude/longitude coordinates provided by the Driver SDK.\n- Customized map elements, such as custom markers, overlays, and UI elements to highlight key navigation information and to personalize the navigation experience.\n\nHow the Navigation SDK works\n\nThe Navigation SDK provides routing information and destination to Fleet Engine,\nwhile the Driver SDK provides a stream of location updates, latitude/longitude\ncoordinates, remaining distance, and ETAs. All other vehicle data updates must\nbe sent to the customer backend, which relays the data to Fleet Engine.\n\nHow to use the Navigation SDK\n\nThe steps below cover a typical use-case scenario for incorporating the\nNavigation SDK into your driver application: \n\nAndroid\n\n|---|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|\n| 1 | **Set up your Google Cloud project** | Create a Google Cloud project before using the Navigation SDK. For more information, see [Set up your Google Cloud project](/maps/documentation/navigation/android-sdk/cloud-setup). |\n| 2 | **Add the Navigation SDK to your API key** | The API key is a unique identifier that authenticates your requests, associate at least one API key with your project to use the Navigation SDK. For more information, see [Using API keys](/maps/documentation/navigation/android-sdk/get-api-key). |\n| 3 | **Set up your Android Studio project** | Create an Android project and integrate the Navigation SDK into it. For more information, see [Set up your Android Studio project](/maps/documentation/navigation/android-sdk/android-studio-setup). |\n| 4 | **Add the Driver SDK to your project** | Install and configure the Driver SDK to start taking advantage of all the Fleet Engine features. For more information, see [Get the Driver SDK for on-demand trips](/maps/documentation/mobility/driver-sdk/on-demand/android/minimum-requirements) and [Get the Driver SDK for scheduled tasks](/maps/documentation/mobility/driver-sdk/scheduled/android/minimum-requirements). |\n\niOS\n\n|---|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|\n| 1 | **Set up your Google Cloud project** | Create a Google Cloud project before using the Navigation SDK. For more information, see [Set up your Google Cloud project](/maps/documentation/navigation/ios-sdk/cloud-setup). |\n| 2 | **Add the Navigation SDK to your API key** | The API key is a unique identifier that authenticates your requests, associate at least one API key with your project to use the Navigation SDK. For more information, see [Using API keys](/maps/documentation/navigation/ios-sdk/get-api-key). |\n| 3 | **Set up your Xcode project** | Create an Xcode project and install the Navigation SDK into it. For more information, see [Set up your Xcode project](/maps/documentation/navigation/ios-sdk/xcode-setup). |\n| 4 | **Add the Driver SDK to your project** | Install and configure the Driver SDK to start taking advantage of all the Fleet Engine features. For more information, see [Get the Driver SDK for on-demand trips](/maps/documentation/mobility/driver-sdk/on-demand/ios/minimum-requirements) and [Get the Driver SDK for scheduled tasks](/maps/documentation/mobility/driver-sdk/scheduled/ios/minimum-requirements). |\n\nFor more information about the Navigation SDK features, see the complete\ndocumentation for Navigation SDK for\n[Android](/maps/documentation/navigation/android-sdk) and\n[iOS](/maps/documentation/navigation/ios-sdk)."]]