Часто задаваемые вопросы

Факты о продукте

Проблемы

Сеть

Данные

Настройка пользовательского интерфейса

Маршрутизация

Симулятор

Рабочие процессы

Факты о продукте

В вашем приложении должно быть реализовано диалоговое окно с уведомлением об Условиях использования Navigation SDK, которое должен принять каждый драйвер. Это диалоговое окно дает водителю возможность согласиться с Условиями обслуживания. Текстовый файл условий предоставляется вместе с Navigation SDK.
В Android используйте метод NavigationApi.showTermsAndConditionsDialog , чтобы отобразить диалоговое окно, содержащее термины.
В iOS вызовите GMSNavigationServices.showTermsAndConditionsDialogIfNeededWithCompanyName .
Любые языки, поддерживаемые Google Maps Mobile, автоматически доступны для навигационного SDK. На устройстве установлен системный язык по умолчанию, и приложение не может изменить этот параметр; однако приложение имеет доступ к более чем 70 языкам.

Да. В Android после запуска LocationListener продолжает работать в фоновом режиме. Ваше приложение продолжает фиксировать положение дороги и поддерживать направление.

В iOS, чтобы продолжать получать обновления местоположения и направления в фоновом режиме, реализуйте привязку дорог и установите для allowsBackgroundLocationUpdates значение YES .

Да. Когда маршрут создается или изменяется, RouteChangeListener предоставляет полилинии.

Нет, для навигационного SDK не требуется установка Google Maps Mobile на устройстве.
Нет, навигационный SDK в настоящее время не предоставляет эту функциональность.
Да. Направление движения доступно и отображается по умолчанию.

Проблемы

В Xcode 12 приложения для симулятора создаются неправильно. Как я могу это исправить?

Чтобы устранить эту проблему, откройте настройки сборки проекта Xcode и добавьте arm64 в список Excluded Architectures только для сборок «iOS Simulator».

Для получения дополнительной информации см. следующую ветку StackOverflow .

Сеть

Как навигационный SDK справляется с плохой связью?
Навигационный SDK предварительно кэширует маршрут для каждой поездки. Предварительно кэшированная информация включает в себя информацию о маршруте за 15-20 минут и альтернативы маршрута на случай отклонения водителя от маршрута. Навигационный SDK определяет местоположение с помощью GPS и датчиков устройства.
Доступен ли автономный режим?
Нет, в настоящее время Navigation SDK не поддерживает автономный режим; однако SDK предоставляет предварительно кэшированную информацию о путешествии.

Данные

Могу ли я получить все остановки/пункты назначения в поездке перед началом маршрута?

Да. В Android, чтобы получить указания по маршруту, вызовите Navigator.getRouteSegments() .

В iOS вызовите GMSNavigator.routeLegs(read) .

Доступно ли пошаговое руководство по маршруту в начале маршрута?
Да. Навигационный SDK предоставляет список сегментов маршрута. Кроме того, водитель может пролистать карточку направлений в заголовке, чтобы увидеть каждый маневр.
Как ETA сообщается пользователям приложения?

В Android выполните следующие действия, чтобы предоставить пользователям приложения информацию о расчетном времени прибытия:

  1. Получите время и расстояние для всех путевых точек, используя Navigator.getTimeAndDistanceList() .
  2. Отправьте эту информацию клиентскому приложению, как вы сейчас делаете это для драйвера ETA.

В iOS выполните следующие действия, чтобы предоставить пользователям приложения информацию о расчетном времени прибытия:

  1. Получите этапы путешествия, используя Navigator.getRouteSegments() .
  2. Вызовите GMSNavigator.timeToNextDestination для каждого участка пути.
  3. Пересылайте информацию о времени в клиентское приложение, как вы сейчас делаете это для драйвера ETA.
Можно ли использовать RoadSnappedLocationProvider для получения текущего местоположения водителя, если навигация не находится на переднем плане?

Да. В Android RoadSnappedLocationProvider по умолчанию работает в фоновом режиме.

В iOS, чтобы навигация работала в фоновом режиме, реализуйте прослушиватель для GMSRoadSnappedLocationProviderListener и установите для allowsBackgroundLocationUpdates значение TRUE .

Поддерживает ли навигационный SDK геозону?

Нет. В контексте навигации remainingTimeOrdistanceChangeListener имеет преимущество перед простой геозоной. Геозона может не учитывать геометрию дороги и не быть сосредоточена точно на той точке, к которой движется водитель.

Вы можете аппроксимировать эту функциональность, используя remainingTimeOrdistanceChangeListener .

  1. Установите порог для определения частоты обратных вызовов.
  2. Проверьте оставшееся расстояние до пункта назначения.

Например, если вы установите пороговое значение 100 м, вы получите обратный вызов, когда расстояние до пункта назначения изменится на 100 м. По мере уменьшения расстояния вы можете обновить этот порог до меньшего значения и получать более частые обратные вызовы. Затем проверьте оставшееся расстояние, чтобы определить, достаточно ли вы близки к месту посадки/высадки.

В iOS реализуйте прослушиватель GMSNavigatorListener.didUpdateRemainingDistance для управления расстоянием между уведомлениями.

Могу ли я отключить уведомления, когда приложение «Навигация» работает в фоновом режиме?

Да. В Android используйте Navigator.setHeadsUpNotificationEnabled для управления уведомлениями. Этот метод имеет логический аргумент. FALSE отключает уведомления; TRUE включает уведомления.

В iOS отключите фоновое уведомление для местоположений с привязкой к дороге, задав для GMSRoadSnappedLocationProvider.allowsBackgroundLocationUpdates значение NO.

Чтобы отключить фоновую обработку других уведомлений о местоположении, вызовите GMSNavigator.sendsBackgroundNotifications(NO) .

Настройка пользовательского интерфейса

Могу ли я раскрасить лучший вариант маршрута?
Нет. Цветовое кодирование определенного варианта маршрута в настоящее время не поддерживается.
Может ли навигационный SDK отображать расчетное время прибытия для конечного пункта назначения?

Да. В Android используйте следующие методы:

  1. Получите время и расстояние для всех путевых точек, используя Navigator.getTimeAndDistanceList() .
  2. Скройте расчетное время прибытия текущей путевой точки, используя NavigationFragment.setEtaCardEnabled(false) .
  3. Отобразите расчетное время прибытия конечного пункта назначения.

В iOS используйте следующее:

  1. Вызовите GMSNavigator.routeLegs(read) .
  2. На последнем этапе вызовите GMSNavigator.timeToNextDestination .
  3. Скройте расчетное время прибытия текущей путевой точки, используя для MSMapView.settings.navigationFooterEnabled=NO значение FALSE.
  4. Отобразите расчетное время прибытия конечного пункта назначения.
Как я могу скрыть обновления ETA?

Вы можете отключить карты ETA следующими способами:

  • В Android используйте navigationView.setEtaCardEnabled(false) .
  • В iOS используйте GMSMapView.settings.navigationFooterEnabled=NO .
Какие настройки пользовательского интерфейса доступны для карточек верхнего и нижнего колонтитула?

В Android вы используете StylingOptions для установки стиля цвета фона. Чтобы скрыть или отобразить верхний и нижний колонтитул, используйте функции-члены setHeaderEnabled и setFooterEnabled NavigationFragment .

В iOS используйте GMSMapView.settings.navigationHeaderPrimaryBackgroundColor , чтобы установить стиль цвета фона. Чтобы скрыть или показать верхний и нижний колонтитул, используйте свойства navigationFooterEnabled и navigationHeaderEnabled GMSUISettings .

Маршрутизация

Могу ли я предоставить водителю конкретный маршрут или удалить альтернативные маршруты?
Нет. По умолчанию предоставляется несколько маршрутов, и самый быстрый маршрут имеет приоритет. Вы можете изменить маршрут по умолчанию, добавив в свой запрос такие настройки, как «избегать автомагистралей и платных дорог». Добавление путевых точек также влияет на маршрут.
Могу ли я показать пользователю приложения метку места назначения, отличную от местоположения назначения по умолчанию?

Да. В Android создайте Marker с собственным названием пункта назначения и широтой/долготой. Navigation SDK отображает пользовательский заголовок и координаты на NavigationMap .

В iOS вы создаете и отображаете GMSMarker для пункта назначения.

Могу ли я использовать Navigation SDK для отслеживания отклонений от заданного пути?

Да. В Android используйте Navigator.setRouteChangedListener для получения уведомлений об изменении маршрута или рекомендации нового маршрута:

  1. Зарегистрируйте прослушиватель, который проверяет положение устройства на маршруте с помощью метода Navigator.setRouteChangedListener .
  2. Добавьте код в обработчик событий обратного вызова onRouteChanged :
    • Отправьте пользователю приложения сообщение с обновленной информацией о расчетном времени прибытия и расстоянии.
    • Отслеживайте местоположение устройства.
    • [необязательно] Добавьте другие функции, необходимые вашему приложению для обработки случаев, когда водитель отклоняется от предписанного маршрута.

В iOS используйте GMSNavigator и его прослушиватели для получения уведомлений при изменении маршрута или рекомендации нового маршрута:

  1. В контроллере представления карты реализуйте протокол GMSNavigatorListener и протокол GMSRoadSnappedLocationProviderListener .
  2. Реализуйте GMSNavigatorListener.navigatorDidChangeRoute .
  3. Получите доступ к новому маршруту, используя свойства routeLegs и currentRouteLeg GMSNavigator .
Может ли водитель выйти из навигации, не пройдя маршрут?

Да. В Android вызовите метод Navigator.stopGuidance() чтобы остановить навигацию.

В iOS вызовите GMSNavigator.clearDestinations .

Симулятор

Поддерживает ли симулятор изменения маршрута?

Да. В Android вызовите simulateLocationsAlongNewRoute , чтобы смоделировать путешествие, включающее изменение маршрута. Метод simulateLocationsAlongExistingRoute игнорирует изменения существующего маршрута.

В iOS используйте GMSLocationSimulator.simulateAlongNewRouteToDestinations , чтобы имитировать путешествие, включающее изменение маршрута. Если вы не ожидаете каких-либо изменений маршрута, вы можете использовать GMSLocationSimulator.simulateLocationsAlongExistingRoute или GMSLocationSimulator.simulateAlongNewRouteToDestinations .

Рабочие процессы

Как закрыть уведомление после закрытия активности, содержащей фрагмент навигации?

Уведомление о навигации остается видимым во время навигации, когда действие закрыто. Когда автомобиль прибудет в пункт назначения, навигация прекратится, а уведомление исчезнет.

Для обработки кликов по уведомлению используйте Navigator.startGuidance(intent resumeIntent) . resume intent срабатывает, когда пользователь приложения щелкает уведомление. Обычно Navigator.startguidance(getIntent()) вызывается из основного действия, которое вызывает действие, когда пользователь приложения щелкает уведомление.