Следуйте этому руководству, чтобы построить маршрут в вашем приложении с помощью Navigation SDK для Android. В этом руководстве предполагается, что вы уже интегрировали Navigation SDK в свое приложение, как описано в разделе «Настройка проекта» .
Краткое содержание
- Добавьте в приложение элемент пользовательского интерфейса, либо в виде фрагмента навигации, либо в виде навигационного представления. Этот элемент пользовательского интерфейса добавит интерактивную карту и пошаговую навигацию в ваше приложение.
- Запросите разрешение на определение местоположения. Ваше приложение должно запросить разрешение на определение местоположения, чтобы определить местоположение устройства.
- Инициализируйте SDK, используя класс
NavigationApi. Задайте пункт назначения и управляйте пошаговой навигацией с помощью класса
Navigator. Это включает в себя три шага:- Укажите пункт назначения с помощью
setDestination(). - Начать навигацию можно с помощью
startGuidance(). - Используйте
getSimulator()для имитации движения транспортного средства по маршруту в целях тестирования, отладки и демонстрации вашего приложения.
- Укажите пункт назначения с помощью
Создайте и запустите своё приложение.
См. код
Добавьте элемент пользовательского интерфейса в ваше приложение.
В этом разделе рассматриваются два способа добавления интерактивной карты и пользовательского интерфейса для отображения пошаговой навигации. В большинстве случаев мы рекомендуем использовать SupportNavigationFragment , который является оберткой для NavigationView , вместо прямого взаимодействия с NavigationView . Для получения дополнительной информации см. раздел «Рекомендации по взаимодействию с навигационной картой» .
Используйте фрагмент навигации
Компонент SupportNavigationFragment — это элемент пользовательского интерфейса, отображающий визуальный результат навигации, включая интерактивную карту и пошаговые инструкции. Вы можете объявить этот фрагмент в своем XML-файле разметки, как показано здесь:
<?xml version="1.0" encoding="utf-8"?>
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
android:name="com.google.android.libraries.navigation.SupportNavigationFragment"
android:id="@+id/navigation_fragment"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
В качестве альтернативы, вы можете создать фрагмент программно, как описано в документации Android , используя FragmentActivity.getSupportFragmentManager() .
Используйте навигационное меню.
В качестве альтернативы фрагменту, компонент пользовательского интерфейса для отображения карты для навигации также доступен в виде NavigationView .
Запросить разрешение на определение местоположения
В этом разделе показано, как запросить разрешение на определение местоположения. Для получения более подробной информации см. руководство по разрешениям Android .
Добавьте разрешение в качестве дочернего элемента элемента
<manifest>в вашем Android-манифесте:<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.navsdksingledestination"> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> </manifest>В вашем приложении запрашиваются разрешения во время выполнения, предоставляя пользователю возможность разрешить или запретить доступ к местоположению. Следующий код проверяет, предоставил ли пользователь разрешение на доступ к местоположению. Если нет, он запрашивает разрешение:
if (ContextCompat.checkSelfPermission(this.getApplicationContext(), android.Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) { mLocationPermissionGranted = true; } else { ActivityCompat.requestPermissions(this, new String[] { android.Manifest.permission.ACCESS_FINE_LOCATION }, PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION); } if (!mLocationPermissionGranted) { displayMessage("Error loading Navigation SDK: " + "The user has not granted location permission."); return; }Переопределите функцию обратного вызова
onRequestPermissionsResult()для обработки результата запроса на разрешение:@Override public void onRequestPermissionsResult(int requestCode, @NonNull String permissions[], @NonNull int[] grantResults) { mLocationPermissionGranted = false; switch (requestCode) { case PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION: { // If request is canceled, the result arrays are empty. if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { mLocationPermissionGranted = true; } } } }
Инициализация SDK навигации
Класс NavigationApi предоставляет логику инициализации, которая разрешает вашему приложению использовать навигацию Google. В этом разделе описывается, как инициализировать навигатор, а также некоторые другие параметры конфигурации, которые вы можете включить для своего приложения:
Инициализируйте SDK навигации и переопределите функцию обратного вызова
onNavigatorReady(), чтобы начать навигацию, когда навигатор будет готов.Необязательно. Настройте приложение таким образом, чтобы уведомления о поворотах и фоновые службы отключались, когда пользователь закрывает приложение на своем устройстве. Этот выбор зависит от вашей бизнес-модели. Возможно, вы захотите использовать поведение навигатора по умолчанию, которое продолжает отображать подсказки по поворотам и обновления местоположения даже после закрытия приложения. Если же вы хотите отключить навигацию и обновления местоположения после закрытия приложения конечным пользователем, используйте эту конфигурацию.
Необязательно. Включите ограничения движения по дорогам в поддерживаемых странах. Установите последнюю цифру номерного знака. Этот вызов необходимо выполнить только один раз: последующие запросы на построение маршрута будут использовать его. Этот вызов работает только в поддерживаемых регионах. См. раздел «Поддерживаемые страны в Navigation SDK» .
NavigationApi.getNavigator(this, new NavigationApi.NavigatorListener() { /** * Sets up the navigation UI when the navigator is ready for use. */ @Override public void onNavigatorReady(Navigator navigator) { displayMessage("Navigator ready."); mNavigator = navigator; mNavFragment = (NavigationFragment) getFragmentManager() .findFragmentById(R.id.navigation_fragment); // Optional. Disable the guidance notifications and shut down the app // and background service when the user closes the app. // mNavigator.setTaskRemovedBehavior(Navigator.TaskRemovedBehavior.QUIT_SERVICE) // Optional. Set the last digit of the car's license plate to get // route restrictions for supported countries. // mNavigator.setLicensePlateRestrictionInfo(getLastDigit(), "BZ"); // Set the camera to follow the device location with 'TILTED' driving view. mNavFragment.getCamera().followMyLocation(Camera.Perspective.TILTED); // Set the travel mode (DRIVING, WALKING, CYCLING, TWO_WHEELER, or TAXI). mRoutingOptions = new RoutingOptions(); mRoutingOptions.travelMode(RoutingOptions.TravelMode.DRIVING); // Navigate to a place, specified by Place ID. navigateToPlace(SYDNEY_OPERA_HOUSE, mRoutingOptions); } /** * Handles errors from the Navigation SDK. * @param errorCode The error code returned by the navigator. */ @Override public void onError(@NavigationApi.ErrorCode int errorCode) { switch (errorCode) { case NavigationApi.ErrorCode.NOT_AUTHORIZED: displayMessage("Error loading Navigation SDK: Your API key is " + "invalid or not authorized to use the Navigation SDK."); break; case NavigationApi.ErrorCode.TERMS_NOT_ACCEPTED: displayMessage("Error loading Navigation SDK: User did not accept " + "the Navigation Terms of Use."); break; case NavigationApi.ErrorCode.NETWORK_ERROR: displayMessage("Error loading Navigation SDK: Network error."); break; case NavigationApi.ErrorCode.LOCATION_PERMISSION_MISSING: displayMessage("Error loading Navigation SDK: Location permission " + "is missing."); break; default: displayMessage("Error loading Navigation SDK: " + errorCode); } } });
Укажите пункт назначения
Класс Navigator предоставляет возможность управлять настройкой, запуском и остановкой навигационного маршрута.
Используя Navigator полученный в предыдущем разделе, задайте конечную Waypoint для этого путешествия. После расчета маршрута SupportNavigationFragment отобразит на карте ломаную линию, представляющую маршрут, и маркер в точке назначения.
```none
private void navigateToPlace(String placeId, RoutingOptions travelMode) {
Waypoint destination;
try {
destination = Waypoint.builder().setPlaceIdString(placeId).build();
} catch (Waypoint.UnsupportedPlaceIdException e) {
displayMessage("Error starting navigation: Place ID is not supported.");
return;
}
// Create a future to await the result of the asynchronous navigator task.
ListenableResultFuture<Navigator.RouteStatus> pendingRoute =
mNavigator.setDestination(destination, travelMode);
// Define the action to perform when the SDK has determined the route.
pendingRoute.setOnResultListener(
new ListenableResultFuture.OnResultListener<Navigator.RouteStatus>() {
@Override
public void onResult(Navigator.RouteStatus code) {
switch (code) {
case OK:
// Hide the toolbar to maximize the navigation UI.
if (getActionBar() != null) {
getActionBar().hide();
}
// Enable voice audio guidance (through the device speaker).
mNavigator.setAudioGuidance(
Navigator.AudioGuidance.VOICE_ALERTS_AND_GUIDANCE);
// Simulate vehicle progress along the route for demo/debug builds.
if (BuildConfig.DEBUG) {
mNavigator.getSimulator().simulateLocationsAlongExistingRoute(
new SimulationOptions().speedMultiplier(5));
}
// Start turn-by-turn guidance along the current route.
mNavigator.startGuidance();
break;
// Handle error conditions returned by the navigator.
case NO_ROUTE_FOUND:
displayMessage("Error starting navigation: No route found.");
break;
case NETWORK_ERROR:
displayMessage("Error starting navigation: Network error.");
break;
case ROUTE_CANCELED:
displayMessage("Error starting navigation: Route canceled.");
break;
default:
displayMessage("Error starting navigation: "
+ String.valueOf(code));
}
}
});
}
```
Создайте и запустите свое приложение.
- Подключите устройство Android к компьютеру. Следуйте инструкциям Android Studio по запуску приложений на аппаратном устройстве. В качестве альтернативы вы можете настроить виртуальное устройство с помощью Android Virtual Device Manager (AVD) . При выборе эмулятора убедитесь, что вы выбрали образ, включающий API Google.
- В Android Studio нажмите пункт меню «Выполнить» или значок кнопки воспроизведения. Выберите устройство согласно подсказке.
Советы по улучшению пользовательского опыта
- Пользователь должен принять Условия использования навигации Google, прежде чем навигация станет доступна. Это требуется только один раз. По умолчанию SDK запрашивает принятие условий при первом запуске навигатора. При желании вы можете запустить диалоговое окно с Условиями использования навигации на более раннем этапе пользовательского интерфейса вашего приложения, например, во время регистрации или входа в систему, используя
TermsAndConditionsCheckOption. - Для значительного повышения качества навигации и точности расчета времени прибытия используйте идентификаторы мест для инициализации путевой точки вместо координат широты/долготы.
- В этом примере целевая точка определяется по идентификатору конкретного места, например, Сиднейского оперного театра. Вы можете использовать инструмент поиска идентификаторов мест , чтобы получить идентификаторы других конкретных мест.