名称

ST_BuildArea — 通过几何图形的线段创建面几何图形。

概要

geometry ST_BuildArea(geometry geom);

描述

根据输入几何图形的组成线段创建面几何图形。输入可以是 LineString、MultiLineString、Polygon、MultiPolygon 或 GeometryCollection。结果是 Polygon 或 MultiPolygon,具体取决于输入。如果输入线段没有形成多边形,则返回 NULL。

ST_MakePolygon 不同,此函数接受由多条线段形成的环,并且可以形成任意数量的多边形。

此函数将内环转换为孔洞。要将内环也转换为多边形,请使用 ST_Polygonize

[Note]

输入线段必须正确节点化才能使此函数正常工作。可以使用 ST_Node 来节点化线段。

如果输入线段交叉,此函数将生成无效的多边形。可以使用 ST_MakeValid 来确保输出有效。

可用性:1.1.0

示例

输入线段

面积结果

WITH data(geom) AS (VALUES
   ('LINESTRING (180 40, 30 20, 20 90)'::geometry)
  ,('LINESTRING (180 40, 160 160)'::geometry)
  ,('LINESTRING (160 160, 80 190, 80 120, 20 90)'::geometry)
  ,('LINESTRING (80 60, 120 130, 150 80)'::geometry)
  ,('LINESTRING (80 60, 150 80)'::geometry)
)
SELECT ST_AsText( ST_BuildArea( ST_Collect( geom )))
    FROM data;

------------------------------------------------------------------------------------------
POLYGON((180 40,30 20,20 90,80 120,80 190,160 160,180 40),(150 80,120 130,80 60,150 80))

从两个圆形多边形创建一个甜甜圈

SELECT ST_BuildArea(ST_Collect(inring,outring))
FROM (SELECT
    ST_Buffer('POINT(100 90)', 25) As inring,
    ST_Buffer('POINT(100 90)', 50) As outring) As t;

另请参阅

ST_Collect, ST_MakePolygon, ST_MakeValid, ST_Node, ST_Polygonize, ST_BdPolyFromText, ST_BdMPolyFromText(具有标准 OGC 接口的此函数的包装器)