Вставьте точки вдоль линии перемены даты, чтобы орудовать шестами
[latf,lonf] = flatearthpoly(lat,lon)
[latf,lonf] = flatearthpoly(lat,lon,longitudeOrigin)
[latf,lonf] = flatearthpoly(lat,lon) обрезки NaN-разделенные полигоны, заданные векторами широты и долготы lat и lon к пределам [-180 180] в долготе и [-90 90] в широте, вставляя прямые сегменты вперед +/-меридианы на 180 градусов и в полюсах. Вводы и выводы в градусах.
[latf,lonf] = flatearthpoly(lat,lon,longitudeOrigin) сосредотачивает пределы долготы на долготе, заданной скалярной долготой longitudeOrigin.
Векторные данные для географических объектов, которые охватывают полюс, неизбежно столкнутся или пересекут линию перемены даты. В то время как тулбокс правильно отображает такие полигоны, они могут вызвать проблемы для функций как пересечение полигона и Логические операции, которые работают с Декартовыми координатами. Когда эти полигоны обработаны как Декартовы координаты, результаты пересечения линии перемены даты в побочном линейном сегменте и полигон, отображенный, когда закрашенной фигуре не заполнили внутреннюю часть правильно.
antarctica = shaperead('landareas', 'UseGeoCoords', true,...
'Selector', {@(name) strcmp(name,'Antarctica'), 'Name'});
figure; plot(antarctica.Lon, antarctica.Lat); ylim([-100 -60])
Полигоны могут быть переформатированы более соответственно для Декартовых координат с помощью функции flatearthpoly. Результат напоминает отображение карты на цилиндрической проекции. Полигон соответствует линии перемены даты, раскрывается к полюсу, развертывается через долготы в полюсе и следует за линией перемены даты до другой стороны пересечения линии перемены даты.
[latf, lonf] = flatearthpoly(antarctica.Lat', antarctica.Lon'); figure; mapshow(lonf, latf, 'DisplayType', 'polygon') ylim([-100 -60]) xlim([-200 200]) axis square

Топология полигона для входных векторов должна быть допустимой. Это означает, что вершины для внешних звонков (основной полигон или “островные” полигоны) должны быть в по часовой стрелке порядке, и любые внутренние звонки (“озера”) должны запуститься в против часовой стрелки порядке для функции, чтобы работать правильно. Можно использовать функцию ispolycw, чтобы проверять, соответствуют ли lat, векторы lon этому критерию, и poly2cw и функциям poly2ccw, чтобы исправить какой-либо что выполнение в неправильном направлении.