ST_Centroid

Определение

ST_Centroid принимает полигон или мультиполигон и возвращает точку, являющуюся центром огибающей геометрии. Это означает, что точка центроида находится посередине между минимальным и максимальным экстентом x и y геометрии.

Синтаксис

sde.st_centroid (pl1 sde.st_geometry)
sde.st_centroid (mpl1 sde.st_geometry)

Тип возврата

ST_Point

Пример

Городской ГИС-техник хочет отобразить мультиполигоны контуров зданий как точки на графике плотности зданий. Контуры зданий хранятся в таблице bfp, созданной и заполненной следующими инструкциями:

CREATE TABLE bfp (
building_id integer,
footprint sde.st_geometry);

INSERT INTO bfp VALUES (
1,
sde.st_polygon ('polygon ((0 0, 0 10, 10 10, 10 0, 0 0))', 0)
);

INSERT INTO bfp VALUES (
2,
sde.st_polygon ('polygon ((20 0, 30 20, 40 0, 20 0))', 0)
);

INSERT INTO bfp VALUES (
3,
sde.st_polygon ('polygon ((20 30, 25 35, 30 30, 20 30))', 0)
);

Функция ST_Centroid возвращает центроид каждого мультиполигона контура здания. Функция ST_AsText преобразует каждую точку центроида в текстовое представление, поддерживаемое приложением.

Oracle

SELECT building_id,
sde.st_astext (sde.st_centroid (footprint)) Centroid
FROM bfp;

BUILDING_ID                   Centroid

   1                     POINT  (5.00000000 5.00000000)
   2                     POINT  (30.00000000 10.00000000)
   3                     POINT  (25.00000000 32.50000000)

PostgreSQL

SELECT building_id,
sde.st_astext (sde.st_centroid (footprint)) 
AS centroid
FROM bfp;

building_id                  centroid

   1                     POINT  (5 5)
   2                     POINT  (30 10)
   3                     POINT  (25 33)
12/10/2012