• 设为首页
  • 加入收藏
  • 我要投稿
  • 联系站长
  • 网站模板技术交流
当前位置:模板网首页 > 建站教程 > 地图,GIS教程 >  百度获取经纬度,以正文

百度获取经纬度,以及省市区,BMap.Geolocation()

作者:网页模板
类型:文章教程
点击次数:
发布时间:2018-07-11 16:50
分享到:
之前获取经纬度坐标,都是使用的html5 pius封装的html5的方法(文章末尾有提供),下面记下百度直接获取经纬度(百度定位有三种方法:浏览器定位、IP定位和SDK辅助定位,这里是浏览器定位的代码):
//单纯的获取,不应用到地图上
var geolocation = new BMap.Geolocation();
geolocation.getCurrentPosition(function(r){
    if(this.getStatus() == BMAP_STATUS_SUCCESS){
        console.log(JSON.stringify(r));
    }else {
        console.log('failed'+this.getStatus());
    }
});

//应用到地图上
var map = new BMap.Map("allmap");  //allmap为显示地图容器的ID
var point = new BMap.Point(116.331398,39.897445);
map.centerAndZoom(point,12);

var geolocation = new BMap.Geolocation();
geolocation.getCurrentPosition(function(r){
    if(this.getStatus() == BMAP_STATUS_SUCCESS){
        var mk = new BMap.Marker(r.point);
        map.addOverlay(mk);
        map.panTo(r.point);
    }else {
        console.log('failed'+this.getStatus());
    }
});
下面是html5 plus获取经纬度的方法:
    注:html5获取的经纬度是GPS坐标,不能直接用在百度地图上,需要转换成百度坐标,即BD-09。上面的代码已经转换过了。
mui.plusReady(function(){
    var curLat = plus.webview.currentWebview().lat;
    var curLon = plus.webview.currentWebview().long;
    initMap(curLat,curLon);
})

function initMap(curLat,curLon){
    //将传递的坐标转为百度坐标
    var bdPos = bd_encrypt(curLon, curLat);
    
    var point = new BMap.Point(bdPos.bd_lon, bdPos.bd_lat); //创建点坐标
    //设置百度地图
    var map = new BMap.Map('map');   //map为显示百度地图的容器的ID
    map.centerAndZoom(point,18);  //设置地图中心
    //自定义图标
    var icon = new BMap.Icon('../images/bdmap_marker.png', new BMap.Size(66,47), {
        anchor: new BMap.Size(33,33)
    });
    var marker = new BMap.Marker(point, {
        icon: icon
    });
    map.addOverlay(marker); //加入覆盖物
}

//火星坐标转百度坐标
function bd_encrypt(gg_lon, gg_lat){  
    var X_PI = Math.PI * 3000.0 / 180.0;  
    var x = gg_lon, y = gg_lat;  
    var z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * X_PI);  
    var theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * X_PI);  
    var bd_lon = z * Math.cos(theta) + 0.0065;  
    var bd_lat = z * Math.sin(theta) + 0.006;  
    return {  
        bd_lat: bd_lat,  
        bd_lon: bd_lon  
    };  
} 

(责任编辑:网页模板)
  • 本文标签:
  • geolocation
GPS坐标单个和批量转为百度地图坐标(WGS84转BD-09)
没有下一篇