地理 Feed¶
GeoDjango 拥有自己的 Feed
子类,可以根据 Simple GeoRSS 或 W3C Geo 标准格式化的 RSS/Atom 源中嵌入位置信息。由于 GeoDjango 的聚合 API 是 Django 的超集,请查阅 Django的聚合文档 以获取一般使用的详细信息。
例如¶
API 参考¶
Feed
子类¶
- class Feed[source]¶
除了
django.contrib.syndication.views.Feed
基类提供的方法之外,GeoDjango 的Feed
类还提供了以下覆盖方法。请注意,可以以多种方式进行这些覆盖操作:from django.contrib.gis.feeds import Feed class MyFeed(Feed): # First, as a class attribute. geometry = ... item_geometry = ... # Also a function with no arguments def geometry(self): ... def item_geometry(self): ... # And as a function with a single argument def geometry(self, obj): ... def item_geometry(self, item): ...
- geometry(obj)¶
使用
get_object()
返回的对象,并返回 feed 的几何形状。通常情况下,这是一个GEOSGeometry
实例,或者可以是一个表示点或矩形框的元组。例如:class ZipcodeFeed(Feed): def geometry(self, obj): # Can also return: `obj.poly`, and `obj.poly.centroid`. return obj.poly.extent # tuple like: (X0, Y0, X1, Y1).
- item_geometry(item)¶
将此设置为返回 feed 中每个 item 的几何形状。这可以是一个
GEOSGeometry
实例,或者是表示点坐标或边界框的元组。例如:class ZipcodeFeed(Feed): def item_geometry(self, obj): # Returns the polygon. return obj.poly