在Geodjango + Postgres中存放一个圆圈

时间:2012-06-07 23:26:27

标签: django postgresql postgis geodjango

想要在geodjango字段中存储一个圆圈,这样我就可以使用geodjango查询__contains来查明一个点是否在圆圈内(类似于PolygonField可以做到的)。

目前将其存储为十进制半径和GeoDjango点域,但需要一种方法来查询数据库中的位置列表,使得这些变化的圆(点域和半径)包含我的搜索点(长/纬)。

希望它有意义。

1 个答案:

答案 0 :(得分:2)

从技术上讲,PostGIS支持CurvePolygonCircularString几何类型,可用于存储曲线几何。例如,x = 10,y = 10的2单位半径已经被64点缓冲多边形近似:

SELECT ST_AsText(ST_LineToCurve(ST_Buffer(ST_MakePoint(10, 10), 2, 16)));
                   st_astext
------------------------------------------------
 CURVEPOLYGON(CIRCULARSTRING(12 10,8 10,12 10))
(1 row)

但是,这种方法通常不会完成,因为对此几何类型的支持非常有限(即ST_AsSVG,而其他类型则不起作用)。这些几何类型可能会导致很多悲伤,我建议不要这样做。

通常,所有几何都存储为支持良好的类型:POINTLINESTRINGPOLYGON(带有可选的MULTI-前缀)。对于这些类型,请使用ST_DWithin function(例如{_ 3}}调用此__dwithin,另请参阅GeoDjango)来查询另一个几何是否在指定距离内。例如,如果您有一个点位置,您可以看到其他几何是否在该点之内的某个距离内(即 radius )。