Adición de un polígono directamente en Geodjango / PostGIS
-
19-09-2019 - |
Pregunta
Estoy jugando con Geodjango, y sólo quiero añadir un campo polígono simple a una base de datos y ejecutar un punto en el polígono en él para asegurarse de que todo está funcionando bien.
Aquí está mi código en views.py:
#adding a polygon
pe = PolygonExample.objects.create(name="uk_polygon", poly="POLYGON((58.768200159239576, -12.12890625, 58.49369382056807 1.1865234375, 49.18170338770662 -12.9638671875, 50.2612538275847 5.537109375))" )
#doing the point-in-polygon check
result = PolygonExample.objects.filter(poly__contains='POINT(52.696361078274485 -0.87890625)')
y esto es lo que tengo en models.py:
class PolygonExample(models.Model):
name = models.CharField(max_length=16, db_index=True)
poly = models.PolygonField()
objects = models.GeoManager()
Pero cuando intento añadir el polígono (PolygonExample.objects.create), me sale un error:. "Error encontrado comprobación de geometría devuelto desde la función GEOS C "GEOSWKTReader_read"
Es mi código para agregar el mal polígono? No estoy seguro de entender cómo ranura de latitud / longitud coordina directamente.
O se trata de un error de instalación GEOS?
Gracias.
Solución
WKT tiene algunos problemas:
- Coordinar dimensiones están separados por espacios
- pares de coordenadas (o tuplas) están separados por comas
- Coordinar de pedido es (x, y) - que es (lon, lat)
Prueba de un polígono alrededor del Reino Unido debe tener este aspecto:
>>> wkt = "POLYGON((-12.12890625 58.768200159239576, 1.1865234375 58.49369382056807, 5.537109375 50.2612538275847, -12.9638671875 49.18170338770662, -12.12890625 58.768200159239576))"
>>> pe = PolygonExample.objects.create(name="uk_polygon", poly=wkt)
>>> result = PolygonExample.objects.filter(poly__contains='POINT(-0.87890625 52.696361078274485)') # note x,y order here, too
>>> result[0].name
u'uk_polygon'