嗯,我有一张谷歌地图,所有纬度和经度来自数据库,它用Marker显示每个位置。标记可移动。
现在我想在移动每个标记时更新数据库的纬度和经度。有可能使用php或javascript或Ajax。你能给我一个解决方案或建议吗?谢谢。
Javascript代码:
<script type="text/javascript" src="jquery-1.4.4.min.js"></script>
<script src="http://maps.googleapis.com/maps/api/js?sensor=false"
type="text/javascript"></script>
<script type="text/javascript" src="gmap3.js"></script>
<script type="text/javascript">
$(function(){
$('#map').gmap3({
map:{
options:{
center:[23.709920999999998,90.40714299999999],
zoom: 15
}
},
marker:{
values:[
<?php
$sql = mysql_query("select * from parkings where userid != '0'");
while($res = mysql_fetch_array($sql)){
$id = $res['locId'];
$lat = $res['latitude'];
$long = $res['longitude'];
?>
{address:"<?php echo $lat;?>,<?php echo $long;?>"},
<?php
}
?>
],
options:{
draggable: true
},
events: {
click: function(marker, event, context){
markerSelected(context.id);
}
}
}
});
$("#bcolor").click(function(){
var marker = $('#map').gmap3({get: $("#markerId .value").text() });
marker.setIcon(marker.getIcon() ? "" : "http://maps.google.com/mapfiles
/marker_green.png");
});
$("#bremove").click(function(){
$('#map').gmap3({clear: $("#markerId .value").text() });
$("#data").hide();
$("#title").show();
});
});
function markerSelected(id){
var marker = $('#map').gmap3({get:id});
$("#markerId .value").text(id);
$("#latitude .value").text(marker.getPosition().lat());
$("#longitude .value").text(marker.getPosition().lng());
$("#data").show();
$("#title").hide();
}
</script>
Html正文部分代码
<div id="map" class="gmap3"></div>
当我点击每个标记时,它会显示以下部分的纬度和经度:
<div id="latitude">
<span class="label">Latitude : </span>
<span class="value"></span>
</div>
<div id="longitude">
<span class="label">Longitude : </span>
<span class="value"></span>
</div>
答案 0 :(得分:0)
移动标记时,可以使用jQuery获取新的纬度和经度值。
只需为包含值的标记添加ID:
<div id="latitude">
<span class="label" id="gmap_latitude">Latitude : </span>
<span class="value"></span>
</div>
<div id="longitude">
<span class="label" id="gmap_longitude">Longitude : </span>
<span class="value"></span>
</div>
因此,您可以使用jQuery轻松选择它们并获取它们的值。
现在,为了更新数据库,我建议创建一个更新数据库的PHP脚本,并在每次更新标记时使用带有jQuery加载函数(http://api.jquery.com/jQuery.post/)的AJAX调用。您可以使用jQuery事件处理程序跟踪它。