关于GPS经纬度如何转百度经纬度

来源:互联网 发布:淘宝购物车html模板 编辑:程序博客网 时间:2024/05/18 00:27

【转】众所周知地球是一个不规则椭圆体,GIS中的坐标系定义由基准面和地图投影两组参数确定,而基准面的定义则由特定椭球体及其对应的转换参数确定。 基准面是利用特定椭球体对特定地区地球表面的逼近,因此每个国家或地区均有各自的基准面。基准面是在椭球体基础上建立的,椭球体可以对应多个基准面,而基准面只能对应一个椭球体。意思就是无论是谷歌地图、搜搜地图还是高德地图、百度地图区别只是针对不同的大地地理坐标系标准制作的经纬度,不存在准不准的问题,大家都是准的只是参照物或者说是标准不一样。谷歌地图采用的是WGS84地理坐标系(中国范围除外),谷歌中国地图和搜搜中国地图采用的是GCJ02地理坐标系,百度采用的是BD09坐标系,而设备一般包含GPS芯片或者北斗芯片获取的经纬度为WGS84地理坐标系,为什么不统一用WGS84地理坐标系这就是国家地理测绘总局对于出版地图的要求,出版地图必须符合GCJ02坐标系标准了,也就是国家规定不能直接使用WGS84地理坐标系。所以定位大家感觉不准确很多又叫出版地图为火星地图其实只是坐标系不一样而已。这就是为什么设备采集的经纬度在地图上显示的时候经常有很大的偏差,远远超出民用GPS 10米偏移量的技术规范,于是我们就有了谷歌地图纠偏   腾讯搜搜纠偏  混合地图纠偏  百度谷歌互转存在的价值。那如何对谷歌地图纠偏、搜搜soso地图纠偏或者对百度地图纠偏呢,如果用算法目前没有太好的算法直接转换,所以大家采用的都是比对的方法吧地球划分成若干个小块找到地图的偏差量记录下来,然后根据任意经纬度找寻最接近的偏差量加上偏差量就可以实现不同地图之间的经纬度转换。现在有0.01度纠偏经纬度信息,可以提供任意格式,可以直接把经纬度偏移量调整回来。百度地图纠偏信息包含中国海域一共29,699,997条纠偏数据,谷歌地图只包含中国陆地一共12,597,551条纠偏数据。

 

采用百度在线接口转换的Java示例代码:

protected void runTest() throws Throwable {
  
    try {
        BaiduLocation bl = new BaiduLocation();
            bl.gpsx = 120;//经度
            bl.gpsy = 30;//纬度
            GetBaiduLocation(bl);
            if(bl.ok) {
                int baidux = (int)(bl.baidux*1E6);
                int baiduy = (int)(bl.baiduy*1E6);
                // 转换成功,这个坐标是百度专用的
            }
            else {
                /// 转换失败
            }
    }
    catch(Exception ex) {
    }
}
  
class BaiduLocation {
    public float gpsx, gpsy;
    public float baidux, baiduy;
    public boolean ok = false;
}
  
public static String GetBaiduLocation(float x, float y) throws MalformedURLException, IOException {
    String url = String.format("http://api.map.baidu.com/ag/coord/convert?from=0&to=4&x=%f&y=%f", x, y);
    HttpURLConnection urlConnection = (HttpURLConnection)(new URL(url).openConnection());
    urlConnection.connect();
    BufferedReader reader = new BufferedReader(new InputStreamReader(urlConnection.getInputStream()));
    String lines = reader.readLine();
    reader.close(); 
    urlConnection.disconnect();
    return lines;
}    
  
public static boolean GetBaiduLocation(BaiduLocation bl) {
    try {
        bl.ok = false;
        String res = GetBaiduLocation(bl.gpsx, bl.gpsy);
        if(res.startsWith("{") && res.endsWith("}")) {
            res = res.substring(1, res.length() - 2).replace("\"""");
            String[] lines = res.split(",");
            for(String line : lines) {
                String[] items = line.split(":");
                if(items.length == 2) {
                    if("error".equals(items[0])) {
                        bl.ok = "0".equals(items[1]);
                    }
                    if("x".equals(items[0])) {
                        bl.baidux = ConvertBase64(items[1]);
                    }
                    if("y".equals(items[0])) {
                        bl.baiduy = ConvertBase64(items[1]);
                    }
                }
            }
        }
    catch (Exception e) {
        bl.ok = false;
    
    return bl.ok;    
}
private static float ConvertBase64(String str) {
    byte[] bs = Base64.decode(str);        
    return Float.valueOf(new String(bs));
}

 

0 0
原创粉丝点击