172 похожих чатов

Есть path состоящий из массива координат(lat, lng), проецированная от дорог,

естественно для уменьшения размера массива в прямых дорогах координаты только в начале и конце, в поворотах они учащаются.
Вопрос такой: нужно определить, находится ли пользователь в этом path или поблизости какой либо точки(учитывая точки будут каждые 6 метров, напр 15км=2500 точек) этой path до 30 метров.
Есть вариант прогона 2ух массивов(по lat+-x и lng+-x) , ставя в цикл начальную и конечную точку дорог, но мне кажется это будет слишком ресурсоемко. Есть ли у кого опыт с подобным поиском?

2 ответов

11 просмотров

Генерируешь из линии полигон с нужной тебе шириной(30 метров). На каждый сегмент этого полигона строишь свой bbox. В цикле прогоняешь попадание точки в эти получившиеся bbox'ы. Если попадание есть, то проверяешь попадание в полигон. Перед началом цикла можно проверить попадание в общих bbox полигона. Работать будет очень быстро даже на сотнях тысяч точек.

Есть еще и третий вариант. Генерализируешь линию(упрощаешь) алгоритмом дугласа-пекера, от 2500 точек может остаться 100-200 всего. Потом уже решать проще.

Похожие вопросы

Обсуждают сегодня

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Ну вот просто даже давайте вот как. Какой нибудь конкретный кейс, можете в пример привести, где бч работает и приносит прикладную пользу, а не просто что бы было? Не крипту.
Alexander Andreev
22
объясните пожалуйста, почему функция не работает должным образом? вроде должно брать активное окно сравнивать его размер с размером экрана, и если есть совпадение = true прове...
JF
12
Мне вот любопытно. Уже сколько времени имею соблазн купить макбук, ибо подозреваю что очень уж удобен будет в связке с другой техникой от эпл которая у меня есть, да и сам по ...
Not Yeromin
14
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
> Копаем глубже > Следующий момент был, когда я спросил его, знает ли он JavaScript. Он ответил, что его учили работать с C#. Я тоже в университете писал на C#, но даже там мн...
Oleg Volkov
4
Гляньте, че бывает: Сегодня по одному проекту одной вебстудии делал проект небольшой, на их хостинге. На Modx revo. В определенный момент , работая в админке, вдруг перестал р...
Artem
5
И никого не интересует какие пакеты кто использует. ((% Заходишь на сайт симфони и видишь поддержку Украины - по законам РФ это ж экстремизм. Только никто не отказывается от с...
Am Ambrion
11
Чтобы перехватить все нажимания буков на форме, надо хук ставить? Пробовал на форме ОнКейДаун, оно ловит клаву если фокус не на компоненте с вводом текста
Serjone
15
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
8
Карта сайта