geo_intersects_2lines()
Platí pro: ✅Microsoft Fabric✅Azure Data Explorer✅Azure Monitor✅Microsoft Sentinel
Vypočítá, zda se protínají dvě čáry nebo víceřádkové čáry.
Syntaxe
geo_intersects_2lines(
lineString1,
lineString2)
Přečtěte si další informace o konvencích syntaxe.
Parametry
Název | Type | Požadováno | Popis |
---|---|---|---|
lineString1 | dynamic |
✔️ | Čára nebo víceřádkový formát GeoJSON. |
lineString2 | dynamic |
✔️ | Čára nebo víceřádkový formát GeoJSON. |
Návraty
Určuje, zda se protínají dvě čáry nebo víceřádkové čáry. Pokud je řetězec lineString nebo multiLineString neplatný, 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žité k měření vzdálenosti na Zemi je sféra. Hrany čar jsou geodesics 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.
Tip
K lepšímu výkonu použijte literál LineString nebo MultiLineString.
Příklady
Následující příklad zkontroluje, zda některé dva literálové řádky protínají.
let lineString1 = dynamic({"type":"LineString","coordinates":[[-73.978929,40.785155],[-73.980903,40.782621]]});
let lineString2 = dynamic({"type":"LineString","coordinates":[[-73.985195,40.788275],[-73.974552,40.779761]]});
print intersects = geo_intersects_2lines(lineString1, lineString2)
Výstup
Protíná |
---|
True |
Následující příklad najde všechny cesty v tabulce cest NYC GeoJSON, které protínají určité čáry zájmu.
let my_road = dynamic({"type":"LineString","coordinates":[[-73.97892951965332,40.78515573551921],[-73.98090362548828,40.78262115769851]]});
NY_Manhattan_Roads
| project name = features.properties.Label, road = features.geometry
| where geo_intersects_2lines(road, my_road)
| project name
Výstup
name |
---|
Broadway |
W 78th St |
W 79th St |
W 80th St |
W 81st St |
Následující příklad vrátí výsledek null, protože jeden z řádků je neplatný.
let lineString1 = dynamic({"type":"LineString","coordinates":[[-73.978929,40.785155],[-73.980903,40.782621]]});
let lineString2 = dynamic({"type":"LineString","coordinates":[[-73.985195,40.788275]]});
print isnull(geo_intersects_2lines(lineString1, lineString2))
Výstup
print_0 |
---|
Pravda |