Навигация по маршруту с одним пунктом назначения

Следуйте этому руководству, чтобы построить маршрут в вашем приложении с помощью Navigation SDK для Android. Предполагается, что вы уже интегрировали Navigation SDK в свое приложение, как описано в разделе «Настройка проекта» .

Краткое содержание

  1. Добавьте элемент пользовательского интерфейса в своё приложение, например, фрагмент навигации или навигационное представление. Этот элемент добавляет интерактивную карту и пошаговую навигацию в вашу активность.
  2. Запрос разрешения на определение местоположения. Ваше приложение должно запрашивать разрешение на определение местоположения, чтобы определить местоположение устройства.
  3. Инициализируйте SDK с помощью класса NavigationApi .
  4. Задайте пункт назначения и управляйте пошаговой навигацией с помощью класса Navigator . Это включает три этапа:

    • Установите пункт назначения с помощью setDestination() .
    • Начните навигацию с помощью startGuidance() .
    • Используйте getSimulator() для имитации движения транспортного средства по маршруту, для тестирования, отладки и демонстрации вашего приложения.
  5. Создайте и запустите свое приложение.

Посмотреть код

Добавьте элемент пользовательского интерфейса в свое приложение

В этом разделе рассматриваются два способа добавления интерактивной карты и пользовательского интерфейса для отображения пошаговой навигации. В большинстве случаев мы рекомендуем использовать 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 .

  1. Добавьте разрешение как дочерний элемент элемента <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>
    
  2. Запросите разрешения на доступ к данным о местоположении в вашем приложении, предоставляя пользователю возможность предоставить или отклонить разрешение на доступ к данным о местоположении. Следующий код проверяет, предоставил ли пользователь разрешение на доступ к данным о местоположении. Если нет, он запрашивает разрешение:

        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;
        }
    
  3. Переопределите обратный вызов 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;
                    }
                }
            }
        }
    

Инициализируйте Navigation SDK

Класс NavigationApi предоставляет логику инициализации, которая разрешает вашему приложению использовать навигацию Google. В этом разделе рассматривается инициализация навигатора, а также некоторые другие конфигурации, которые вы можете включить в своем приложении:

  1. Инициализируйте Navigation SDK и переопределите обратный вызов onNavigatorReady() для запуска навигации, когда навигатор будет готов.

  2. Необязательно. Настройте приложение так, чтобы уведомления с подсказками и фоновые службы отключались при закрытии приложения пользователем на устройстве. Этот выбор зависит от вашей бизнес-модели. Возможно, вы захотите использовать стандартное поведение навигатора, при котором подсказки с поворотами и обновления местоположения продолжают отображаться даже после закрытия приложения. Если же вы хотите, чтобы навигация и обновления местоположения отключались при закрытии приложения пользователем, используйте эту конфигурацию.

  3. Необязательно. Включите ограничения на дорогах в поддерживаемых странах. Задайте последнюю цифру номерного знака. Этот вызов необходимо выполнить только один раз: последующие запросы маршрутов будут использовать его. Этот вызов работает только в поддерживаемых регионах. См. раздел «Поддерживаемые страны 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));
                        }
                    }
                });
    }
```

Создайте и запустите свое приложение

  1. Подключите устройство Android к компьютеру. Следуйте инструкциям Android Studio по запуску приложений на аппаратном устройстве. Кроме того, вы можете настроить виртуальное устройство с помощью диспетчера виртуальных устройств Android (AVD) . При выборе эмулятора убедитесь, что выбранный вами образ включает API Google.
  2. В Android Studio выберите пункт меню «Выполнить» или значок кнопки воспроизведения. Выберите устройство в появившемся окне.

Советы по улучшению пользовательского опыта

  • Пользователь должен принять Условия использования навигации Google, прежде чем навигация станет доступной. Это требуется только один раз. По умолчанию SDK запрашивает согласие при первом вызове навигатора. При желании вы можете открыть диалоговое окно «Условия использования навигации» на раннем этапе пользовательского опыта вашего приложения, например, во время регистрации или входа в систему, с помощью TermsAndConditionsCheckOption .
  • Чтобы значительно улучшить качество навигации и точность определения времени прибытия, используйте идентификаторы мест для инициализации точки маршрута вместо координат широты/долготы.
  • В этом примере точка назначения определяется на основе идентификатора Сиднейского оперного театра. Вы можете использовать функцию поиска идентификаторов мест , чтобы получить идентификаторы других конкретных мест.