想要在geodjango字段中存储一个圆圈,这样我就可以使用geodjango查询__contains来查明一个点是否在圆圈内(类似于PolygonField可以做到的)。
目前将其存储为十进制半径和GeoDjango点域,但需要一种方法来查询数据库中的位置列表,使得这些变化的圆(点域和半径)包含我的搜索点(长/纬)。
希望它有意义。
答案 0 :(得分:2)
从技术上讲,PostGIS支持CurvePolygon
和CircularString
几何类型,可用于存储曲线几何。例如,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
,而其他类型则不起作用)。这些几何类型可能会导致很多悲伤,我建议不要这样做。
通常,所有几何都存储为支持良好的类型:POINT
,LINESTRING
或POLYGON
(带有可选的MULTI-
前缀)。对于这些类型,请使用ST_DWithin
function(例如{_ 3}}调用此__dwithin,另请参阅GeoDjango)来查询另一个几何是否在指定距离内。例如,如果您有一个点位置,您可以看到其他几何是否在该点之内的某个距离内(即 radius )。