zoukankan      html  css  js  c++  java
  • 通过百度地图API将百度坐标转换成GPS经纬度

    百度地图API链接:http://developer.baidu.com/map/index.php?title=webapi/guide/changeposition

    百度地图API中,有GPS坐标转百度坐标的功能 
    http://dev.baidu.com/wiki/static/map/API/examples/?v=1.2&0_6#0&6 

    http接口是:http://api.map.baidu.com/ag/coord/convert?from=0&to=4&x=116.397428&y=39.90923&callback=BMap.Convertor.cbk_7594 
    返回结果坐标是通过base64加密的。 
    这个转换算法百度是不会公开的,而且百度也没有提供百度坐标转成GPS坐标功能,这里我用了取巧的办法。 

    百度坐标和GPS坐标转换在很近的距离时偏差非常接近。 
    假设你有百度坐标:x1=116.397428,y1=39.90923 
    把这个坐标当成GPS坐标,通过接口获得他的百度坐标:x2=116.41004950566,y2=39.916979519873 

    通过计算就可以得到GPS的坐标: 
    x = 2*x1-x2,y = 2*y1-y2 
    x=116.38480649434001 
    y=39.901480480127 

    http://dev.baidu.com/wiki/static/map/API/examples/?v=1.2&0_6#0&6 将此坐标输入GPS数据项中得到的结果是:116.39743826208,39.909194650838 

    实现的java代码如下:

    package com.dataprocess;
    
    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.io.PrintWriter;
    import java.net.URL;
    import java.net.URLConnection;
    import java.util.List;
    import java.util.Map;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    
    public class CopyOfTest {
        public static void main(String args[]){
            String params = 
                    "coords=114.21892734521,29.575429778924&from=1&to=5&ak=ZQU8ZGeBf95nN8wY1cNL13NP&output=json";
            
            String s=CopyOfTest.sendGet("http://api.map.baidu.com/geoconv/v1/?", params); 
            String[] s1 = s.split("\[");
            String[] s2 = s1[1].split(",");
            String regEx ="[^0-9.\+\-\s]"; 
            Pattern p = Pattern.compile(regEx); 
            Matcher m1 = p.matcher(s2[0]);
            Matcher m2 = p.matcher(s2[1]);
            String[] arrs1=m1.replaceAll("").trim().split("\s");
            String[] arrs2=m2.replaceAll("").trim().split("\s");
            System.out.println(s1[1]);
            System.out.println(arrs1[0]+" "+arrs2[0]);
            
        }
        public static String sendGet(String url, String param) {
            String result = "";
            BufferedReader in = null;
            try {
                String urlNameString = url  + param;
                URL realUrl = new URL(urlNameString);
                // 打开和URL之间的连接
                URLConnection connection = realUrl.openConnection();
                // 设置通用的请求属性
                connection.setRequestProperty("accept", "*/*");
                connection.setRequestProperty("connection", "Keep-Alive");
                connection.setRequestProperty("user-agent",
                        "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
                // 建立实际的连接
                connection.connect();
                // 获取所有响应头字段
                Map<String, List<String>> map = connection.getHeaderFields();
                // 遍历所有的响应头字段
    //            for (String key : map.keySet()) {
    //                System.out.println(key + "--->" + map.get(key));
    //            }
                // 定义 BufferedReader输入流来读取URL的响应
                in = new BufferedReader(new InputStreamReader(
                        connection.getInputStream(),"utf-8"));
                String line;
                while ((line = in.readLine()) != null) {
                    result += line;
                }
            } catch (Exception e) {
                System.out.println("发送GET请求出现异常!" + e);
                e.printStackTrace();
            }
            // 使用finally块来关闭输入流
            finally {
                try {
                    if (in != null) {
                        in.close();
                    }
                } catch (Exception e2) {
                    e2.printStackTrace();
                }
            }
            return result;
        }
    
        /**
         * 向指定 URL 发送POST方法的请求
         * 
         * @param url
         *            发送请求的 URL
         * @param param
         *            请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
         * @return 所代表远程资源的响应结果
         */
        public static String sendPost(String url, String param) {
            PrintWriter out = null;
            BufferedReader in = null;
            String result = "";
            try {
                URL realUrl = new URL(url);
                // 打开和URL之间的连接
                URLConnection conn = realUrl.openConnection();
                // 设置通用的请求属性
                conn.setRequestProperty("accept", "*/*");
                conn.setRequestProperty("connection", "Keep-Alive");
                conn.setRequestProperty("user-agent",
                        "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
                // 发送POST请求必须设置如下两行
                conn.setDoOutput(true);
                conn.setDoInput(true);
                // 获取URLConnection对象对应的输出流
                out = new PrintWriter(conn.getOutputStream());
                // 发送请求参数
                out.print(param);
                // flush输出流的缓冲
                out.flush();
                // 定义BufferedReader输入流来读取URL的响应
                in = new BufferedReader(
                        new InputStreamReader(conn.getInputStream()));
                String line;
                while ((line = in.readLine()) != null) {
                    result += line;
                }
            } catch (Exception e) {
                System.out.println("发送 POST 请求出现异常!"+e);
                e.printStackTrace();
            }
            //使用finally块来关闭输出流、输入流
            finally{
                try{
                    if(out!=null){
                        out.close();
                    }
                    if(in!=null){
                        in.close();
                    }
                }
                catch(IOException ex){
                    ex.printStackTrace();
                }
            }
            return result;
        }    
    
    }

    同时实现读取文本中的百度经纬度坐标实现批量处理并生成gpx格式文档(可上传到openstreetmap形成轨迹)代码如下:

    package com.dataprocess;
    
    import java.io.BufferedReader;
    import java.io.BufferedWriter;
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.io.OutputStreamWriter;
    import java.net.URL;
    import java.net.URLConnection;
    import java.util.List;
    import java.util.Map;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    
    public class CopyOfGenerateGpx {
        public void generate(){
            String fileNames[]={"LocationData_2015-09-15",
                    "LocationData_2015-09-16"
                    };
            int n = fileNames.length;
            for(String fileName: fileNames){
                //输入文件
                File filein = new File("H:\项目数据\测试\"+fileName+".txt");
                //输出文件
                File fileout = new File("H:\项目数据\测试\gpx\"+fileName+".gpx");
                //输出json文件
                File jsonfile = new File("H:\项目数据\测试\json\JSON_"+fileName+".json");
                try {
                    //输入流
                    FileInputStream fis = new FileInputStream(filein);
                    InputStreamReader isr = new InputStreamReader(fis);
                    BufferedReader br = new BufferedReader(isr);
                    //输出流
                    FileOutputStream fos = new FileOutputStream(fileout);
                    OutputStreamWriter osw = new OutputStreamWriter(fos);
                    BufferedWriter bw = new BufferedWriter(osw);
                    //json输出流
                    FileOutputStream fos1 = new FileOutputStream(jsonfile);
                    OutputStreamWriter osw1 = new OutputStreamWriter(fos1);
                    BufferedWriter bw1 = new BufferedWriter(osw1);
                    bw1.write("[
    ");
                    bw.write("<?xml version="1.0" encoding="UTF-8"?>
    ");
                    bw.write("<gpx version="1.1" creator="OSMTrack" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.topografix.com/GPX/1/1""
                            + " xsi:schemaLocation="http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd">
    ");
                    bw.write("<trk>
    <trkseg>
    ");
                    String line = null;
                    String regEx ="[^0-9.\+\-\s]"; 
                    Pattern p = Pattern.compile(regEx); 
                    while((line=br.readLine())!=null){
                        Matcher m = p.matcher(line);
                        String[] arrs=m.replaceAll("").trim().split("\s");
                        String lonbd = arrs[2];
                        String latbd = arrs[3];
                        String params = 
                                "coords="
                                + lonbd+","+latbd
                                + "&from=1&to=5&ak=ZQU8ZGeBf95nN8wY1cNL13NP&output=json";    
                        String s=sendGet("http://api.map.baidu.com/geoconv/v1/?", params);
                        String[] s1 = s.split("\[");
                        String[] s2 = s1[1].split(",");
                        Matcher m1 = p.matcher(s2[0]);
                        Matcher m2 = p.matcher(s2[1]);
                        String[] arrs1=m1.replaceAll("").trim().split("\s");
                        String[] arrs2=m2.replaceAll("").trim().split("\s");
                        System.out.println(s1[1]);
                        System.out.println(arrs1[0]+" "+arrs2[0]);
                        double lon = 2*Double.parseDouble(lonbd)-Double.parseDouble(arrs1[0]);
                        double lat = 2*Double.parseDouble(latbd)-Double.parseDouble(arrs2[0]);
                        String str = "<trkpt lat=""+lat+"" lon=""+lon+""><ele>61.3</ele><time>2015-09-05T14:12:20Z</time></trkpt>";
                        bw.write(str+"
    ");
                        String str1 = "{"
                                +""longitude": "+lon 
                                +","latitude": "+lat                   
                                  +"},
    ";
                        bw1.write(str1);
                        System.out.println(str);
                    }
                    bw.write("</trkseg>
    </trk>
    </gpx>
    ");
                    bw.flush();
                    bw1.write("]
    ");
                    bw1.flush();
                    br.close();
                    fis.close();
                    bw.close();
                    fos.close();
                } catch (FileNotFoundException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }
        
        public static String sendGet(String url, String param) {
            String result = "";
            BufferedReader in = null;
            try {
                String urlNameString = url  + param;
                URL realUrl = new URL(urlNameString);
                // 打开和URL之间的连接
                URLConnection connection = realUrl.openConnection();
                // 设置通用的请求属性
                connection.setRequestProperty("accept", "*/*");
                connection.setRequestProperty("connection", "Keep-Alive");
                connection.setRequestProperty("user-agent",
                        "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
                // 建立实际的连接
                connection.connect();
                // 获取所有响应头字段
                Map<String, List<String>> map = connection.getHeaderFields();
                // 遍历所有的响应头字段
    //            for (String key : map.keySet()) {
    //                System.out.println(key + "--->" + map.get(key));
    //            }
                // 定义 BufferedReader输入流来读取URL的响应
                in = new BufferedReader(new InputStreamReader(
                        connection.getInputStream(),"utf-8"));
                String line;
                while ((line = in.readLine()) != null) {
                    result += line;
                }
            } catch (Exception e) {
                System.out.println("发送GET请求出现异常!" + e);
                e.printStackTrace();
            }
            // 使用finally块来关闭输入流
            finally {
                try {
                    if (in != null) {
                        in.close();
                    }
                } catch (Exception e2) {
                    e2.printStackTrace();
                }
            }
            return result;
        }
        
        public static void main(String[] args){
            CopyOfGenerateGpx g = new CopyOfGenerateGpx();
            g.generate();
        }
    }
  • 相关阅读:
    left join,right join,join的区别
    java反编译工具
    maven搭建Struts2+Hibernate+Spring
    JAVA验证是否是Email地址和验证是否是手机号码
    jquery的强大选择器
    JavaScript事件委托的技术原理
    Hybrid APP混合开发的一些经验和总结
    React实例入门教程(1)基础API,JSX语法--hello world
    Vue.js 和 MVVM 的小细节
    前端构建工具gulpjs的使用介绍及技巧
  • 原文地址:https://www.cnblogs.com/gaopeng527/p/4818300.html
Copyright © 2011-2022 走看看