geo_simplify_polygons_array()
Upraszcza wielokąty, zastępując prawie proste łańcuchy krótkich krawędzi pojedynczą długą krawędzią na Ziemi.
Składnia
geo_simplify_polygons_array(
Wielokątów,
Tolerancji)
Dowiedz się więcej o konwencjach składniowych.
Parametry
Nazwa | Typ | Wymagane | Opis |
---|---|---|---|
Wielokąt | dynamic |
✔️ | Wielokąt lub multipolygon w formacie GeoJSON. |
Tolerancji | int, long, or real | Definiuje minimalną odległość w metrach między dowolnymi dwoma wierzchołkami. Obsługiwane wartości znajdują się w zakresie [0, ~7 800 000 metrów]. Jeśli nie zostanie określona, zostanie użyta wartość 10 domyślna. |
Zwraca
Uproszczony wielokąt lub wielobieg w formacie GeoJSON i dynamicznym typie danych bez dwóch wierzchołków o odległości mniejszej niż tolerancja. Jeśli wielokąt lub tolerancja jest nieprawidłowa, zapytanie zwróci wynik o wartości null.
Uwaga
- Jeśli dane wejściowe są pojedynczym wielokątem, zobacz geo_polygon_simplify().
- Współrzędne geoprzestrzenne są interpretowane jako reprezentowane przez system odniesienia współrzędnych WGS-84 .
- Geodetic datum używane do pomiarów na Ziemi jest sferą. Krawędzie wielokątne są geodesykami na sferze.
- Jeśli krawędzie wielokąta wejściowe są prostymi liniami kartezjańskimi, rozważ użycie geo_polygon_densify() w celu przekonwertowania krawędzi planarnych na geodesyki.
- Jeśli dane wejściowe są wielobiegunem i zawierają więcej niż jeden wielokąt, wynik będzie obszarem unii wielokątów.
- Wysoka tolerancja może spowodować zniknięcie małego wielokąta.
Definicja i ograniczenia wielokątne
dynamic({"type": "Polygon","coordinates": [ LinearRingShell, LinearRingHole_1, ..., LinearRingHole_N ]})
dynamic({"type": "MultiPolygon","współrzędne": [[ LinearRingShell, LinearRingHole_1, ..., LinearRingHole_N ], ..., [LinearRingShell, LinearRingHole_1, ..., LinearRingHole_M]]})
- Program LinearRingShell jest wymagany i zdefiniowany jako uporządkowana tablica współrzędnych
counterclockwise
[[lng_1,lat_1],...,[lng_i,lat_i],...,[lng_j,lat_j],...,[lng_1,lat_1]]. Może istnieć tylko jedna powłoka. - Element LinearRingHole jest opcjonalny i zdefiniowany jako uporządkowana tablica współrzędnych
clockwise
[[lng_1,lat_1],...,[lng_i,lat_i],...,[lng_j,lat_j],...,[lng_1,lat_1]]. Może istnieć dowolna liczba wewnętrznych pierścieni i otworów. - Wierzchołki liniowe muszą być różne z co najmniej trzema współrzędnymi. Pierwsza współrzędna musi być równa ostatniej. Wymagane są co najmniej cztery wpisy.
- Współrzędne [długość geograficzna, szerokość geograficzna] muszą być prawidłowe. Długość geograficzna musi być liczbą rzeczywistą w zakresie [-180, +180], a szerokość geograficzna musi być liczbą rzeczywistą w zakresie [-90, +90].
- LinearRingShell otacza najwyżej połowę kuli. Funkcja LinearRing dzieli sferę na dwa regiony. Zostaną wybrane mniejsze z dwóch regionów.
- Długość krawędzi liniowej musi być mniejsza niż 180 stopni. Zostanie wybrana najkrótsza krawędź między dwoma wierzchołkami.
- Linijki nie mogą być krzyżowe i nie mogą współdzielić krawędzi. Wierzchołki liniowe mogą udostępniać wierzchołki.
Przykłady
Poniższy przykład upraszcza wielokąty z wzajemnymi granicami (stanami USA), usuwając wierzchołki znajdujące się w odległości 100 metrów od siebie.
US_States
| project polygon = features.geometry
| summarize lst = make_list(polygon)
| project polygons = geo_simplify_polygons_array(lst, 100)
Dane wyjściowe
Wielokątów |
---|
{ "type": "MultiPolygon", "współrzędne": [ ... ]]} |
Poniższy przykład zwraca wartość True, ponieważ jeden z wielokątów jest nieprawidłowy.
datatable(polygons:dynamic)
[
dynamic({"type":"Polygon","coordinates":[[[-73.9495,40.7969],[-73.95807,40.80068],[-73.98201,40.76825],[-73.97317,40.76455],[-73.9495,40.7969]]]}),
dynamic({"type":"Polygon","coordinates":[[[-73.94622,40.79249]]]}),
dynamic({"type":"Polygon","coordinates":[[[-73.97335,40.77274],[-73.9936,40.76630],[-73.97171,40.75655],[-73.97335,40.77274]]]})
]
| summarize arr = make_list(polygons)
| project is_invalid_polygon = isnull(geo_simplify_polygons_array(arr))
Dane wyjściowe
is_invalid_polygon |
---|
1 |
Poniższy przykład zwraca wartość True z powodu nieprawidłowej tolerancji.
datatable(polygons:dynamic)
[
dynamic({"type":"Polygon","coordinates":[[[-73.9495,40.7969],[-73.95807,40.80068],[-73.98201,40.76825],[-73.97317,40.76455],[-73.9495,40.7969]]]}),
dynamic({"type":"Polygon","coordinates":[[[-73.94622,40.79249],[-73.96888,40.79282],[-73.9577,40.7789],[-73.94622,40.79249]]]}),
dynamic({"type":"Polygon","coordinates":[[[-73.97335,40.77274],[-73.9936,40.76630],[-73.97171,40.75655],[-73.97335,40.77274]]]})
]
| summarize arr = make_list(polygons)
| project is_null = isnull(geo_simplify_polygons_array(arr, -1))
Dane wyjściowe
is_null |
---|
1 |
Poniższy przykład zwraca wartość True, ponieważ wysoka tolerancja powoduje zniknięcie wielokąta.
datatable(polygons:dynamic)
[
dynamic({"type":"Polygon","coordinates":[[[-73.9495,40.7969],[-73.95807,40.80068],[-73.98201,40.76825],[-73.97317,40.76455],[-73.9495,40.7969]]]}),
dynamic({"type":"Polygon","coordinates":[[[-73.94622,40.79249],[-73.96888,40.79282],[-73.9577,40.7789],[-73.94622,40.79249]]]}),
dynamic({"type":"Polygon","coordinates":[[[-73.97335,40.77274],[-73.9936,40.76630],[-73.97171,40.75655],[-73.97335,40.77274]]]})
]
| summarize arr = make_list(polygons)
| project is_null = isnull(geo_simplify_polygons_array(arr, 10000))
Dane wyjściowe
is_null |
---|
1 |
Opinia
https://aka.ms/ContentUserFeedback.
Dostępne już wkrótce: W 2024 r. będziemy stopniowo wycofywać zgłoszenia z serwisu GitHub jako mechanizm przesyłania opinii na temat zawartości i zastępować go nowym systemem opinii. Aby uzyskać więcej informacji, sprawdź:Prześlij i wyświetl opinię dla