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

А источников ошибок много — плотная застройка, подземные парковки, тоннели и зоны с нестабильным сигналом. Чтобы приложение оставалось рабочим даже в таких условиях, мы стараемся улучшить систему позиционирования.

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

Проблемы геопозиционирования 

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

Вот, например, пользователь в Казани едет по дороге, на карте трек идёт ровно, и вдруг — скачок. Машина как будто взлетает над домами, а потом возвращается обратно. 

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

  1. Некорректное определение геопозиции. Когда вдруг оказывается, что вы не на Садовом, а где‑нибудь в Шереметьево. Это массовая история — Москва, Петербург, Казань, Пермь, почти любой крупный город.

  2. Невозможность получить координаты по спутникам. На  Android в таком случае спасают Wi‑Fi и сотовые сети, пусть и приблизительно. А на iOS чаще всего всё просто замирает: карта стоит, курсор не шевелится, и сделать ничего нельзя. 

Пока мы не включили собственные механизмы фильтрации, поездка в таких условиях выглядела как мучение: маршрут «прыгал», карта крутилась, навигатор всё время перестраивался. Сейчас ситуация меняется — появились собственные инструменты, и про это дальше.

Откуда вообще берётся геопозиция

Когда говорят «GPS», чаще всего имеют в виду спутниковое позиционирование в целом. Но вообще GPS — это только одна из навигационных систем. Помимо американской GPS есть российский ГЛОНАСС, европейская Galileo и китайская BeiDou. Современные устройства используют несколько из них одновременно — это называется GNSS (Global Navigation Satellite System).

Но спутники— не единственный источник. Телефон также ориентируется по Wi‑Fi, сотовым вышкам, Bluetooth‑маячкам и показаниям собственных датчиков. Операционная система смешивает всё это и выдаёт приложению итоговую координату — ту самую «точку на карте».

Как именно это устроено — зависит от платформы. На iOS есть только системный Location Manager. Если замолчал — данных нет вообще. У Android побогаче — есть GPS (GNSS), есть network‑позиционирование по Wi‑Fi и сотам, есть «фьюжн‑сервисы» вроде GMS и HMS, которые объединяют спутники, сети и попытки оценить положение. Работают они по‑разному, детали закрыты у производителей, но мы видим разницу даже по тому, какие спутники выбираются.

Чтобы не быть полностью зависимыми от операционных систем, мы также развиваем собственные, двагисовские, источники. 

Когда все источники смотрят в разные стороны

Мы исследовали поведение разных систем на реальных поездках и смотрели на сигналы: GMS (fusion от Google), Network, некоторые другие и их «сумму».

Ниже пример на основе маршрута в Москве. GMS какое‑то время всё делал правильно, а потом отправил пользователя в Шереметьево — и больше не вернулся. Network тоже прыгал через речку, задерживался, но в конечном итоге, хоть и рывками, довёл до конца. А когда всё это наивно смешали — получился сущий кошмар. Точки дергаются туда‑сюда, карту кидает, укачает любого.

 

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

Обработка геопозиции 

Мы выстроили систему, которая анализирует поведение каждого источника и выбирает тот, которому можно доверять в текущий момент. Конкретные критерии и архитектуру раскрывать не будем, но если обобщить — система смотрит не на отдельные точки, а на их поведение во времени.

Отдельно мы научились определять ситуации, когда ни одному источнику доверять нельзя. В таких случаях приложение предлагает пользователю самому указать, где он находится — появляется кнопка «Уточните местоположение».

Кнопка включается только если наше приложение замечает, что текущее местоположение определяется неточно
Кнопка включается только если наше приложение замечает, что текущее местоположение определяется неточно

Для навигатора у нас тоже появился отдельный режим — «Шаг за шагом».

В этом режиме вместо непрерывного трекинга по координатам мы используем цепочку опорных точек. Перемещение происходит по предрасчитанным шагам в реальном мире: манёвр, перекрёсток, съезд, платный участок или промежуточная точка. Всё это удалось сделать благодаря богатым и точным данные о городе в нашей карте. 

Что дальше 

Мы закрыли базовые сценарии — теперь приложение устойчиво работает даже в сложных условиях, а навигация умеет вести пользователя пошагово, когда спутников нет.

И ещё мы готовим ряд фич, которые адаптируют и другие сценарии. Задача не меняется: сделать так, чтобы навигация и позиционирование в 2ГИС оставались стабильными. 

Комментарии (7)


  1. nerudo
    27.04.2026 08:22

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


  1. shasoftZ
    27.04.2026 08:22

    Открывая статью думал прочитать алгоритм, а прочитал рекламу 2ГИС


    1. NataliaZheltova Автор
      27.04.2026 08:22

      Справедливо. Хотелось бы дать больше деталей, но пока так. Старались задачу и контекст описать честно — какие источники есть, как они себя ведут и с чем сталкиваемся.

      Если появился вопрос/интерес к конкретной теме  — напишите, пожалуйста! Попробуем раскрыть в следующий раз.


  1. 000-Vladimir-000
    27.04.2026 08:22

    Всегда, когда говорят о проблемах с геолокацией при недоступности спутников, сотовой связи, Wi-Fi, мне непонятно в чём проблема для пеших передвижений определить точные координаторы? Есть же топографические карты, есть же датчики в смартфоне, которых вполне достаточно, чтобы с точностью до сантиметров определить локацию субъекта.

    Если известна начальная координата, то далее по цифровому компасу, акселерометру, барометру и гироскопу с использованием точной карты местности и построек, можно точно определить не только координаты, но и этаж/квартиру и прочее в здании.


  1. slog2
    27.04.2026 08:22

    А источников ошибок много — плотная застройка, подземные парковки, тоннели и зоны с нестабильным сигналом.

    А основную проблему появившуюся в последнее время назвать нельзя, потому что она из-за того, кого назвать нельзя. И как проблему решали тоже назвать нельзя. Ниочем, просто реклама 2гис.


    1. NataliaZheltova Автор
      27.04.2026 08:22

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


  1. 000-Vladimir-000
    27.04.2026 08:22

    @NataliaZheltova немного не в тему.

    Глянул на 2ГИС здание офиса, в котором сейчас сижу. На 2ГИС написано 4 этажа, по факту этажей 5, просто верхний 5-ый - это мансардный полноценный этаж под скатной крышей. Предположу, что в 2ГИС используется какой-то ИИ, который банально читает кол-во окон и делает неверные выводы об этажности. Думал, 2ГИС более опирается на юр- и техдокументацию по зданиям в этом плане.