GeoDjango possède sa propre sous-classe Feed
qui peut contenir des informations d’emplacement dans les flux RSS/Atom mis en forme selon les standards Simple GeoRSS ou W3C Geo. Comme l’API du système de syndication de GeoDjango est un sur-ensemble de celle de Django, référez-vous à la documentation du système de syndication de Django pour plus de détails sur son utilisation générale.
Feed
¶Feed
[source]¶En plus de méthodes fournies par la classe de base django.contrib.syndication.views.Feed
, la classe Feed
de GeoDjango ajoute les éléments ci-dessous qui peuvent être surchargés. Cette surcharge peut se faire de plusieurs manières :
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)¶Accepte l’objet renvoyé par get_object()
et renvoie la géométrie du flux. Il s’agit typiquement d’une instance GEOSGeometry
ou d’un tuple représentant un point un ou rectangle. Par exemple :
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)¶Définissez ceci pour renvoyer la géométrie de chaque élément du flux. Il peut s’agir d’une instance GEOSGeometry
ou d’un tuple représentant les coordonnées d’un point ou d’un rectangle englobant. Par exemple :
class ZipcodeFeed(Feed):
def item_geometry(self, obj):
# Returns the polygon.
return obj.poly
SyndicationFeed
¶Les sous-classes suivantes de django.utils.feedgenerator.SyndicationFeed
sont disponibles :
Note
Les flux mis en forme selon W3C Geo ne prennent en charge que les géométries de type PointField
.
avr. 04, 2017