JSP 火星坐标及GPS坐标 转百度坐标

来源:互联网 发布:淘宝商城充气姓娃好吗 编辑:程序博客网 时间:2024/06/11 11:03


转自: http://blog.csdn.net/ma969070578/article/details/38257691



1、火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换算法

 

关于 GCJ-02 和 BD-09 ,请参考 http://developer.baidu.com/map/question.htm#qa0043 。

算法代码如下,其中 bd_encrypt 将 GCJ-02 坐标转换成 BD-09 坐标, bd_decrypt 反之。

#include <math.h> 
 
const double x_pi = 3.14159265358979324 * 3000.0 / 180.0; 
 
void bd_encrypt(double gg_lat, double gg_lon, double &bd_lat, double &bd_lon) 

    double x = gg_lon, y = gg_lat; 
    double z = sqrt(x * x + y * y) + 0.00002 * sin(y * x_pi); 
    double theta = atan2(y, x) + 0.000003 * cos(x * x_pi); 
    bd_lon = z * cos(theta) + 0.0065; 
    bd_lat = z * sin(theta) + 0.006; 

 
void bd_decrypt(double bd_lat, double bd_lon, double &gg_lat, double &gg_lon) 

    double x = bd_lon - 0.0065, y = bd_lat - 0.006; 
    double z = sqrt(x * x + y * y) - 0.00002 * sin(y * x_pi); 
    double theta = atan2(y, x) - 0.000003 * cos(x * x_pi); 
    gg_lon = z * cos(theta); 
    gg_lat = z * sin(theta); 
}  
  

jsp:

var x_pi = 52.35987755982988;
function bd_encrypt(gg_lat, gg_lon) 
    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); 
    bd_lon = z * Math.cos(theta) + 0.0065; 
    bd_lat = z * Math.sin(theta) + 0.006;
   
  //  alert("x"+bd_lon);
   //     alert("y"+bd_lat);
    var point = new BMap.Point(bd_lon, bd_lat);
    return point;
}  



2、GPS坐标转百度坐标

参考:http://developer.baidu.com/map/jsdemo.htm#a5_2


[javascript] view plaincopy在CODE上查看代码片派生到我的代码片
  1. <!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
  5. <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />  
  6. <style type="text/css">  
  7. body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;}  
  8. </style>  
  9. <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=idpDDCCenuVQ3y5eD9xU1BM4"></script>  
  10. <script type="text/javascript" src="http://developer.baidu.com/map/jsdemo/demo/convertor.js"></script>  
  11. <title>GPS转百度</title>  
  12. </head>  
  13. <body>  
  14. <div id="allmap"></div>  
  15. </body>  
  16. </html>  
  17. <script type="text/javascript">  
  18.   
  19. // 百度地图API功能  
  20. //GPS坐标  
  21. var xx = 116.397428;  
  22. var yy = 39.90923;  
  23. var gpsPoint = new BMap.Point(xx,yy);  
  24.   
  25.   
  26. //地图初始化  
  27. var bm = new BMap.Map("allmap");  
  28. bm.centerAndZoom(gpsPoint, 15);  
  29. bm.addControl(new BMap.NavigationControl());  
  30. bm.enableScrollWheelZoom();  
  31. //添加谷歌marker和label  
  32. var markergps = new BMap.Marker(gpsPoint);  
  33. bm.addOverlay(markergps); //添加GPS标注  
  34. var labelgps = new BMap.Label("GPS",{offset:new BMap.Size(20,-10)});  
  35. markergps.setLabel(labelgps); //添加GPS标注  
  36.   
  37.   
  38. //坐标转换完之后的回调函数  
  39. translateCallback = function (point){  
  40.     var marker = new BMap.Marker(point);  
  41.     bm.addOverlay(marker);  
  42.     var label = new BMap.Label("111111",{offset:new BMap.Size(40,-10)});  
  43.     marker.setLabel(label); //添加百度label  
  44.     bm.setCenter(point);  
  45.     alert(point.lng + "," + point.lat);  
  46.     
  47.     
  48. }  
  49.   
  50. for(var i =0 ;i<3;i++){  
  51.   
  52. var xx = 116.397428 + i*5;  
  53. var yy = 39.90923+i*5;  
  54. var gpsPoint22 = new BMap.Point(xx,yy);  
  55.  BMap.Convertor.translate(gpsPoint22,0,translateCallback);     //真实经纬度转成百度坐标  
  56. }  
  57.   
  58.   
  59.   
  60.    
  61. </script>  

0 0
原创粉丝点击