В этом примере показано, как идентифицировать сегменты линий или закрашенных фигур после их объединения в большие NaN
-клипированные векторы. Можно разделить эти многоугольники или векторы линий на сегменты их компонентов с помощью polysplit
функция, которая принимает векторы-столбцы как входы. Чтобы соединить вместе отдельные многоугольники или векторы линий, используйте polyjoin
.
Создайте два NaN
-делимитированные массивы в виде векторов-столбцов.
lat = [45.6 -23.47 78 NaN 43.9 -67.14 90 -89]'; lon = [13 -97.45 165 NaN 0 -114.2 -18 0]';
Разделите векторы-столбцы на отдельные массивы ячеек сегмента линии в NaN
диафрагмы с использованием polysplit
.
[latc,lonc] = polysplit(lat,lon)
latc=2×1 cell array
{3x1 double}
{4x1 double}
lonc=2×1 cell array
{3x1 double}
{4x1 double}
Проверьте содержимое массивов ячеек. Обратите внимание, что каждый элемент массива ячеек содержит сегмент исходной линии.
[latc{1} lonc{1}]
ans = 3×2
45.6000 13.0000
-23.4700 -97.4500
78.0000 165.0000
[latc{2} lonc{2}]
ans = 4×2
43.9000 0
-67.1400 -114.2000
90.0000 -18.0000
-89.0000 0
Чтобы обратить процесс вспять, используйте polyjoin
.
[lat2,lon2] = polyjoin(latc,lonc);
Выполните логическое сравнение соединенных сегментов. Обратите внимание, что они идентичны начальным lat
и lon
массивы. Логическое сравнение ложно для NaN
разделители по определению.
[lat lon] == [lat2 lon2]
ans = 8x2 logical array
1 1
1 1
1 1
0 0
1 1
1 1
1 1
1 1
Тест на глобальное равенство, включая NaN
значения.
isequaln(lat,lat2) & isequaln(lon,lon2)
ans = logical
1