如何使用谷歌地图v3获取用户位置

时间:2013-05-17 11:54:35

标签: google-maps

我一直在尝试使用地图v3获取用户位置,并显示从该位置到固定目的地的路径。但我没有找到解决方案来获取用户位置,我已经阅读了API,但无法弄清楚所有示例仍然是相同的。希望有人可以帮助我Thanx。

3 个答案:

答案 0 :(得分:2)

解决方案:

<script type="text/javascript" src="http://www.google.com/jsapi"></script>
<script type="text/javascript">
function initialize() {
    var loc = {};
    var geocoder = new google.maps.Geocoder();
    if(google.loader.ClientLocation) {
        loc.lat = google.loader.ClientLocation.latitude;
        loc.lng = google.loader.ClientLocation.longitude;

        var latlng = new google.maps.LatLng(loc.lat, loc.lng);
        geocoder.geocode({'latLng': latlng}, function(results, status) {
            if(status == google.maps.GeocoderStatus.OK) {
                alert(results[0]['formatted_address']);
            };
        });
    }
}

google.load("maps", "3.x", {other_params: "sensor=false", callback:initialize});

答案 1 :(得分:0)

google.loader.ClientLocation仅对用户的位置进行非常近似的估算。

如果HTML5地理位置不存在或用户不允许,最佳选择是将其用作后备。

if(navigator.geolocation) {
    navigator.geolocation.getCurrentPosition(
        function(p) {
        //get position from p.coords.latitude and p.coords.longitude
        },
        function() {
            //denied or error
            //use google.loader.ClientLocation
        }
    );
} else {
    //use google.loader.ClientLocation
}

答案 2 :(得分:0)

 jQuery('#map_canvas').gmap({ 'zoom':2,'center':new google.maps.LatLng(39.809734,-98.55562), 'callback': function() {

                var self = this; 
                self.getCurrentPosition(function(position, status) { 
                    if ( status === 'OK' ) {

                        clientlat = position.coords.latitude;
                        clientlon = position.coords.longitude;
                        var clientlatlng = new google.maps.LatLng(clientlat, clientlon);

                    }
                });

          }});