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.

¿Fue útil?

Solución

WKT tiene algunos problemas:

  1. Coordinar dimensiones están separados por espacios
  2. pares de coordenadas (o tuplas) están separados por comas
  3. 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'
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top