DbGeography Union вычитает вместо объединения - PullRequest
1 голос
/ 05 апреля 2019

Я пытаюсь объединить тысячи прямоугольников в один многоугольник, используя DbGeography. Для тестирования я начинаю с двух прямоугольников (потому что тысячи потерпели неудачу с полным результатом). Когда я использую метод объединения DbGeography, он возвращает многоугольник с одним вычтенным прямоугольником из другого вместо их объединения. Я попробовал тот же процесс с SQLGeography и получил тот же результат. Кто-нибудь может увидеть, что я делаю не так? Или, может быть, я неправильно понимаю метод Union?

Два отдельных прямоугольника с перекрытием:

enter image description here

Результирующий многоугольник после объединения:

enter image description here

Код (geog1 - верхний левый прямоугольник, geog2 - нижний правый):

DbGeography geogUnion = geog1;     
geogUnion = geogUnion.Union(geog2);

А вот значения для полигонов, которые я объединяю, и результирующий полигон:

geog1: POLYGON ((-114.964104 36.008963, -114.964104 36.005183, -114.958248 36.005183, -114.958248 36.008963, -114.964104 36.008963))

geog2: POLYGON ((-114.957387 36.006575, -114.957387 36.000681, -114.9608 36.000681, -114.9608 36.006575, -114.957387 36.006575))

geogUnion: POLYGON ((-114.957387 36.000681, -114.9608 36.000681, -114.96080000000012 36.005183034992221, -114.958248 36.005183, -114.95824799999998 36.00657500911889, -114.957387 36.006575, -114.957387 36.000681))

1 Ответ

0 голосов
/ 05 апреля 2019

Я понял это после большого тестирования.Прямоугольники были нарисованы в разных направлениях, то есть один был по часовой стрелке, а другой против часовой стрелки.Это произошло из-за того, что данные, из которых я черпал данные, были непоследовательными в нашей базе данных, определяющей прямоугольники.

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

...