html百度地图自动定位吗,利用HTML5定位功能,实现在百度地图上定位

HTML5定位

*{ margin: 0px; padding: 0px;}

body{text-align: center; height: 100%;overflow:hidden;}

#allmap{ width: 100%;height: 100%; position: absolute;}

$(function(){

if(supportsGeoLocation()){

alert("你的浏览器支持 GeoLocation.");

}else{

alert("不支持 GeoLocation.")

}

// 检测浏览器是否支持HTML5

function supportsGeoLocation(){

return !!navigator.geolocation;

}

// 单次位置请求执行的函数

function getLocation(){

navigator.geolocation.getCurrentPosition(mapIt,locationError);

}

//定位成功时,执行的函数

function mapIt(position){

var lon = position.coords.longitude;

var lat = position.coords.latitude;

// alert("您位置的经度是:"+lon+" 纬度是:"+lat);

var map = new BMap.Map("allmap");

var point = new BMap.Point(""+lon+"",""+lat+"");

map.centerAndZoom(point,19);

var gc = new BMap.Geocoder();

translateCallback = function (point){

var marker = new BMap.Marker(point);

map.addOverlay(marker);

map.setCenter(point);

gc.getLocation(point, function(rs){

var addComp = rs.addressComponents;

if(addComp.province!==addComp.city){

var sContent =

"

你当前的位置是:

" +

"

"+addComp.province + ", " + addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber+"

" +

"

";}

else{

var sContent =

"

你当前的位置是:

" +

"

"+ addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber+"

" +

"

";

}

var infoWindow = new BMap.InfoWindow(sContent);

map.openInfoWindow(infoWindow,point);

});

}

BMap.Convertor.translate(point,0,translateCallback);

}

// 定位失败时,执行的函数

function locationError(error)

{

switch(error.code)

{

case error.PERMISSION_DENIED:

alert("User denied the request for Geolocation.");

break;

case error.POSITION_UNAVAILABLE:

alert("Location information is unavailable.");

break;

case error.TIMEOUT:

alert("The request to get user location timed out.");

break;

case error.UNKNOWN_ERROR:

alert("An unknown error occurred.");

break;

}

}

// 页面加载时执行getLocation函数

window.onload = getLocation;

})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值