Sdílet prostřednictvím


geo_union_lines_array()

Platí pro: ✅Microsoft FabricAzure Data Explorer✅Azure MonitorMicrosoft Sentinel

Vypočítá sjednocení čar nebo víceřádků na Zemi.

Syntaxe

geo_union_lines_array(lineStrings)

Přečtěte si další informace o konvencích syntaxe.

Parametry

Název Type Požadováno Popis
lineStrings dynamic ✔️ Matice čar nebo víceřádků ve formátu GeoJSON.

Návraty

Čára nebo víceřádkový formát GeoJSON a dynamický datový typ. Pokud některý z poskytnutých řádků nebo víceřádkových řádků není platný, dotaz vytvoří výsledek null.

Poznámka:

  • Geoprostorové souřadnice jsou interpretovány jako reprezentované referenčním systémem souřadnic WGS-84 .
  • Geodetické datum používané pro měření na Zemi je sféra. Polygonové hrany jsou geodesické oblasti na kouli.
  • Pokud jsou hrany vstupní čáry rovné kartézské čáry, zvažte použití geo_line_densify() k převodu planárních hran na geodesické čáry.

Definice a omezení řetězce řádků

dynamic({"type": "LineString";"souřadnice": [[lng_1;lat_1], [lng_2;lat_2], ...; [lng_N;lat_N]]})

dynamic({"type": "MultiLineString";"souřadnice": [[line_1; line_2; ..., line_N]})

  • Matice souřadnic linestringu musí obsahovat alespoň dvě položky.
  • Souřadnice [zeměpisná délka, zeměpisná šířka] musí být platné, pokud je zeměpisná délka skutečným číslem v rozsahu [-180, +180] a zeměpisná šířka je reálné číslo v rozsahu [-90, +90].
  • Délka okraje musí být menší než 180 stupňů. Vybere se nejkratší hrana mezi dvěma vrcholy.

Příklady

Následující příklad provádí geoprostorovou sjednocení na řádcích řádků.

datatable(lines:dynamic)
[
    dynamic({"type":"LineString","coordinates":[[-73.95683884620665,40.80502891480884],[-73.95633727312088,40.8057171711177],[-73.95489156246185,40.80510200431311]]}),
    dynamic({"type":"LineString","coordinates":[[-73.95633727312088,40.8057171711177],[-73.95489156246185,40.80510200431311],[-73.95537436008453,40.804413741624515]]}),
    dynamic({"type":"LineString","coordinates":[[-73.95633727312088,40.8057171711177],[-73.95489156246185,40.80510200431311]]})
]
| summarize lines_arr = make_list(lines)
| project lines_union = geo_union_lines_array(lines_arr)

Výstup

lines_union
{"type": "LineString", "coordinates": [-73.95683884620651, 40.805028914808844], [-73.95633727312088, 40.805717171177], [ -73.954891562461853, 40.80510200431312], [-73.955374360084534, 40.80441374162452]]}

Následující příklad provádí geoprostorovou sjednocení na sloupcích řádků.

datatable(line1:dynamic, line2:dynamic)
[
    dynamic({"type":"LineString","coordinates":[[-73.95683884620665,40.80502891480884],[-73.95633727312088,40.8057171711177],[-73.95489156246185,40.80510200431311]]}), dynamic({"type":"LineString","coordinates":[[-73.95633727312088,40.8057171711177],[-73.95489156246185,40.80510200431311],[-73.95537436008453,40.804413741624515]]})
]
| project lines_arr = pack_array(line1, line2)
| project lines_union = geo_union_lines_array(lines_arr)

Výstup

lines_union
{"type": "LineString", "coordinates":[-73.95683884620651, 40.805028914808844], [-73.95633727312088, 40.80571711177], [-73.954891562461853, 40.80510200431312], [-73.955374360084534, 40.80441374162452]]}

Následující příklad vrátí hodnotu True, protože jeden z řádků je neplatný.

datatable(lines:dynamic)
[
    dynamic({"type":"LineString","coordinates":[[-73.95683884620665,40.80502891480884],[-73.95633727312088,40.8057171711177],[-73.95489156246185,40.80510200431311]]}),
    dynamic({"type":"LineString","coordinates":[[1, 1]]})
]
| summarize lines_arr = make_list(lines)
| project invalid_union = isnull(geo_union_lines_array(lines_arr))

Výstup

invalid_union
Pravda