Jon*_*nas 14 python gis django geodjango
我正在使用GEOS API中的"缓冲"方法根据GeoDjango中的点和半径创建一个圆,根据这个答案:GeoDjango:如何根据点和半径创建一个圆
正如一位评论者指出的那样,你必须将半径以km为单位转换为......但是如何?我想这是一个快速的公式,但它对我来说是希腊语.我会感激任何指针.
GEOS django API 中的缓冲区将使用当前坐标系统使用的任何单位创建缓冲区。
如果您将所有内容存储为 4326(以纬度/经度为单位),那么您将不得不找到一些将 KM 转换为度数的棘手方法。但现在你向北走得越远,你的缓冲区就会严重扭曲。
更好的解决方案是将几何体重新投影到保持面积的投影中,通常这种投影可以跟踪以米为单位的单位。
例如,如果您要在北美创建缓冲区,则可以使用此投影,该投影使用米http://spatialreference.org/ref/sr-org/7314/
以下是如何使用 Django GEOS API 执行此操作的示例:
from django.contrib.gis.geos import Point
# Defines a point in lat/long
p = Point(-70, 50)
# This projection defines lat/long coordinate system
p.srid = 4326
# Transform into the 7314 projection using the OGC WKT format to define that projection
p.transform('PROJCS["NA Lambert Azimuthal Equal Area",GEOGCS["GCS_WGS_1984",DATUM["D_WGS_1984",SPHEROID["WGS_1984",6378137.0,298.257223563]],PRIMEM["Greenwich",0.0],UNIT["degree",0.0174532925199433]],PROJECTION["Lambert_Azimuthal_Equal_Area"],PARAMETER["false_easting",0.0],PARAMETER["false_northing",0.0],PARAMETER["longitude_of_center",-100.0],PARAMETER["latitude_of_center",45.0],UNIT["meter",1.0]]')
# Creates a buffered polygon of 1000 meters in radius
poly = p.buffer(1000)
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
17659 次 |
最近记录: |