我尝试使用 floppyforms 进行一些更改:
模型.py:
class LocationPoint(models.Model):
title = models.CharField(max_length=30, null=False, blank=False)
radius = models.DecimalField(max_digits=5, decimal_places=2, null=False, blank=False)
point = models.PointField(srid=4326, null=False, blank=False)
objects = models.GeoManager()
视图.py:
def location_point_new(request):
if request.method == "POST":
form = LocationPointForm(request.POST)
if form.is_valid():
form.save()
return redirect('ui:population-constraint-add')
else:
form = LocationPointForm()
template = 'api/location_point_template.html'
context = RequestContext(request, {'form': form})
return render_to_response(template, context)
表格.py:
class GMapPointWidget(floppyforms.gis.BaseGMapWidget, floppyforms.gis.PointWidget):
google_maps_api_key = 'my-key'
class LocationPointForm(forms.ModelForm):
latitude = forms.DecimalField(
min_value=-90,
max_value=90,
required=True,
)
longitude = forms.DecimalField(
min_value=-180,
max_value=180,
required=True,
)
class Meta:
model = LocationPoint
exclude = []
widgets = {'point': GMapPointWidget(attrs={'map_width': 1000,
'map_height': 500,
'is_point': True,
'mouse_position': True,
'point_zoom': 1})}
def __init__(self, *args, **kwargs):
super(LocationPointForm, self).__init__(*args, **kwargs)
if args: # If args exist
data = args[0]
if data['latitude'] and data['longitude']: # If lat/lng exist
latitude = float(data['latitude'])
longitude = float(data['longitude'])
data['point'] = Point(longitude, latitude) # Set PointField
try:
coordinates = kwargs['instance'].point.tuple # If PointField exists
initial = kwargs.get('initial', {})
initial['latitude'] = coordinates[0] # Set Latitude from coordinates
initial['longitude'] = coordinates[1] # Set Longitude from coordinates
kwargs['initial'] = initial
except (KeyError, AttributeError):
pass
模板.html
{% extends "base.html" %}
{% load staticfiles %}
{% block content %}
{{ form.media }}
<div class="container" xmlns="http://www.w3.org/1999/html" xmlns="http://www.w3.org/1999/html">
<div class="page-header">
<h1>Location Point</h1>
</div>
<form role="form" class="form-inline" action="" method="post" enctype="multipart/form-data" novalidate>
{% csrf_token %}
<div class="dl-horizontal">
<a href="{% url 'ui:population-constraint-add' %}">
<button type="button" class="btn btn-info">Back</button>
</a>
</div>
<br/>
<br/>
{{ form.as_p }}
<div class="dl-horizontal">
<button type="submit" class="btn btn-success">Save</button>
</div>
<br/>
<br/>
</form>
</div>
{% endblock %}
我对这段代码有三个问题:
- 默认缩放太近了...... GMapPointWidget 中的小部件设置point_zoom没有做任何事情。
- 正如您在上面的屏幕截图中看到的那样,我尝试使用lat,lon (31.0461, 34.8516)将点设置为以色列,但该点位于海洋中……为什么?有不同的纬度计算吗?
- 我该如何做相反的事情,我的意思是我想在地图上设置一个点并查看框中的纬度、经度数据???