Google Map API 如何为当前位置设置标记
Posted
技术标签:
【中文标题】Google Map API 如何为当前位置设置标记【英文标题】:Google Map API how to set marker for current location 【发布时间】:2014-03-25 11:20:40 【问题描述】:我正在学习 google map API,当我尝试将当前坐标添加到数组时遇到了这个问题。这是我的代码:
var locations = [];
在 initialize() 中我有:
function initialize()
infowindow = new google.maps.InfoWindow();
var myOptions =
zoom: 10,
mapTypeControl: true,
navigationControl: true,
map = new google.maps.Map(document.getElementById("map"), myOptions);
add_location('Place 1', 37.2846372, -123.3270422);
set_current_location();
set_markers(new google.maps.LatLngBounds(), map);
第一个标记已设置,而 set_current_location() 似乎不起作用。以下是其余代码:
// add new location to the locations array
function add_location(description, lastitude, longtitude)
locations.push([description, lastitude, longtitude]);
// Set all the markers in the location arrays and bound/frame the map
function set_markers(bounds, map)
for (i = 0; i < locations.length; i++)
marker = new google.maps.Marker(
position: new google.maps.LatLng(locations[i][1], locations[i][2]),
map: map
);
bounds.extend(marker.position);
google.maps.event.addListener(marker, 'click', (function (marker, i)
return function ()
infowindow.setContent(locations[i][0]);
infowindow.open(map, marker);
)(marker, i));
map.fitBounds(bounds);
// Get current location based on the IP Address
function set_current_location()
if (navigator.geolocation)
navigator.geolocation.getCurrentPosition(function (position)
var pos = new google.maps.LatLng(position.coords.latitude,
position.coords.longitude);
var myLat = position.coords.latitude;
var myLong = position.coords.longitude;
add_location('My location', position.coords.latitude, position.coords.longitude);
);
else
alert("Geolocation is not supported by this browser.");
谁能帮助或给我一个提示?我想将当前位置添加到位置数组中,这样我就可以跟踪我添加了多少位置。非常感谢。
【问题讨论】:
在getCurrentPosition
的回调结束时调用set_markers
,而不是在initialize
中。检索用户位置是一个异步过程,初始化完成后结果尚不可用。
我同意莫勒博士的观点。我看到了同样的事情。 getCurrentPosition() 是在后台执行的异步调用,因此在上面的代码中不能保证当 set_markers() 被调用时 getCurrentPosition() 已经完成。将 set_markers() 调用放在 getCurrentPosition() 的末尾将保证用户的地理位置将在标记放置在地图上之前完成。
【参考方案1】:
如果您只是将set_markers()
移动到getCurrentPosition()
的success
回调的末尾并且用户拒绝分享他的位置,您将不会获得地图,而只会获得灰色区域。没有为您的地图设置center
,这是必需的属性。最好这样定义:
var myOptions =
zoom: 10,
center: new google.maps.LatLng(37.339386, -121.894955),
mapTypeControl: true,
navigationControl: true,
map = new google.maps.Map(document.getElementById("map"), myOptions);
...
另外,你也可以在getCurrentPosition()
的error
回调结束时调用set_markers()
,这样万一用户拒绝分享他的位置,你可以显示可用位置:
// Get current location based on the IP Address
function set_current_location()
if (navigator.geolocation)
navigator.geolocation.getCurrentPosition(function (position)
/*
var pos = new google.maps.LatLng(position.coords.latitude,
position.coords.longitude);
var myLat = position.coords.latitude;
var myLong = position.coords.longitude;
*/
add_location('My location',
position.coords.latitude,
position.coords.longitude);
set_markers(new google.maps.LatLngBounds(), map);
, function error(err)
console.log('error: ' + err.message);
set_markers(new google.maps.LatLngBounds(), map);
);
else
alert("Geolocation is not supported by this browser.");
见example at jsbin
【讨论】:
谢谢,您的代码实际上解决了问题,但我的目标远不止于此。我想将当前位置的位置(长/最后)保存到数组方向以供进一步使用。不幸的是,在 set_current_location() 之后,当前位置没有被推送到数组中。如何获取/保存该数据?谢谢 你如何检查?如果您在set_current_location()
之后检查initialize()
函数,那么您将得到错误的结果,因为getCurrentPosition()
是异步函数。您必须检查 locations
在 add_location()
函数中的变化。如果我分享我的位置,我会更新标记和变量locations
。查看更新的 jsbin 示例并打开控制台日志。以上是关于Google Map API 如何为当前位置设置标记的主要内容,如果未能解决你的问题,请参考以下文章
Angularjs - ng-map - Google Maps Javascript API v3 - 如何为多个标记设置最佳缩放
如何为未知目的地实施 Google Directions API?
如何为 Google Places API 自动完成文本框设置默认值
Google Places API 网络服务:如何为自动完成设置多种类型