geo_polygon_centroid()
Область применения: ✅Microsoft Fabric✅Azure Data Explorer✅Azure Monitor✅Microsoft Sentinel
Вычисляет центроид многоугольника или многополигона на Земле.
Синтаксис
geo_polygon_centroid(
многоугольник)
Дополнительные сведения о соглашениях синтаксиса.
Параметры
Имя (название) | Type | Обязательно | Описание |
---|---|---|---|
многоугольник | dynamic |
✔️ | Многоугольник или многополигон в формате GeoJSON. |
Возвраты
Значения координат центра в формате GeoJSON и динамический тип данных. Если многоугольник или многополигон недопустимы, запрос выдает результат NULL.
Примечание.
- Геопространственные координаты интерпретируются как представленные эталонной системой координат WGS-84 .
- Геопоток, используемый для измерений на Земле, является сферой. Границы многоугольников — геодесик на сфере.
- Если ребра входных многоугольников являются прямыми декартовыми линиями, рассмотрите возможность использования geo_polygon_densify() для преобразования плановых ребер в геодесик.
- Если входные данные являются многоугольниками и содержат несколько многоугольников, результатом будет центроид объединения многоугольников.
Определение и ограничения многоугольника
dynamic({"type": "Polygon","координаты": [ LinearRingShell, LinearRingHole_1, ..., LinearRingHole_N ]})
dynamic({"type": "MultiPolygon","координаты": [[ LinearRingShell, LinearRingHole_1, ..., LinearRingHole_N], ..., [LinearRingShell, LinearRingHole_1, ..., ..., LinearRingHole_M]})
- LinearRingShell является обязательным и определяется как упорядоченный
counterclockwise
массив координат [[lng_1,lat_1]],...,[lng_i,lat_i],...,[lng_j;lat_j]],...,[lng_1,lat_1]]. Может быть только одна оболочка. - LinearRingHole является необязательным и определяется как упорядоченный
clockwise
массив координат [[lng_1,lat_1],...,[lng_i,lat_i],...,[lng_j;lat_j]],...,[lng_1,lat_1]]. Может быть любое количество внутренних колец и отверстий. - Вершины LinearRing должны отличаться по крайней мере тремя координатами. Первая координата должна быть равна последней. Требуются по крайней мере четыре записи.
- Координаты [долгота, широта] должны быть допустимыми. Долгота должна быть реальным числом в диапазоне [-180, +180], а широта должна быть реальным числом в диапазоне [-90, +90].
- LinearRingShell заключает в себя не более половины сферы. LinearRing делит сферу на два региона и выбирает меньшее из двух регионов.
- Длина края линейного ринга должна быть меньше 180 градусов. Выбран самый короткий край между двумя вершинами.
- Линейные ринги не должны пересекать границы и не должны совместно использовать края. LinearRings может совместно использовать вершины.
Примеры
В следующем примере вычисляется центроид Центрального парка в Нью-Йорке.
let central_park = dynamic({"type":"Polygon","coordinates":[[[-73.9495,40.7969],[-73.95807266235352,40.80068603561921],[-73.98201942443848,40.76825672305777],[-73.97317886352539,40.76455136505513],[-73.9495,40.7969]]]});
print centroid = geo_polygon_centroid(central_park)
Выходные данные
центроид |
---|
{"type": "Point", "координаты": [-73.965735689907618, 40.78250538057812]} |
В следующем примере вычисляется долгота Центрального парка.
let central_park = dynamic({"type":"Polygon","coordinates":[[[-73.9495,40.7969],[-73.95807266235352,40.80068603561921],[-73.98201942443848,40.76825672305777],[-73.97317886352539,40.76455136505513],[-73.9495,40.7969]]]});
print
centroid = geo_polygon_centroid(central_park)
| project lng = centroid.coordinates[0]
Выходные данные
Спг |
---|
-73.9657356899076 |
В следующем примере выполняется объединение многоугольников в многоугольнике и вычисляется центроид единого многоугольника.
let polygons = dynamic({"type":"MultiPolygon","coordinates":[[[[-73.9495,40.7969],[-73.95807266235352,40.80068603561921],[-73.98201942443848,40.76825672305777],[-73.97317886352539,40.76455136505513],[-73.9495,40.7969]]],[[[-73.94262313842773,40.775991804565585],[-73.98107528686523,40.791849155467695],[-73.99600982666016,40.77092185281977],[-73.96150588989258,40.75609977566361],[-73.94262313842773,40.775991804565585]]]]});
print polygons_union_centroid = geo_polygon_centroid(polygons)
Выходные данные
polygons_union_centroid |
---|
"type": "Point", "координаты": [-73.96856958295777, 40.77631075255119]} |
В следующем примере визуализируется центроид Центрального парка на карте.
let central_park = dynamic({"type":"Polygon","coordinates":[[[-73.9495,40.7969],[-73.95807266235352,40.80068603561921],[-73.98201942443848,40.76825672305777],[-73.97317886352539,40.76455136505513],[-73.9495,40.7969]]]});
print
centroid = geo_polygon_centroid(central_park)
| render scatterchart with (kind = map)
Выходные данные
Следующий пример возвращается true
из-за недопустимого многоугольника.
print isnull(geo_polygon_centroid(dynamic({"type": "Polygon","coordinates": [[[0,0],[10,10],[10,10],[0,0]]]})))
Выходные данные
print_0 |
---|
true |