码迷,mamicode.com
首页 > 其他好文 > 详细

火星坐标系(GCJ-02)与百度坐标系(BD-09)转换

时间:2015-06-01 16:12:59      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:

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

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

  1. #include <math.h>  
  2.   
  3. const double x_pi = 3.14159265358979324 * 3000.0 / 180.0;  
  4.   
  5. void bd_encrypt(double gg_lat, double gg_lon, double &bd_lat, double &bd_lon)  
  6. {  
  7.     double x = gg_lon, y = gg_lat;  
  8.     double z = sqrt(x * x + y * y) + 0.00002 * sin(y * x_pi);  
  9.     double theta = atan2(y, x) + 0.000003 * cos(x * x_pi);  
  10.     bd_lon = z * cos(theta) + 0.0065;  
  11.     bd_lat = z * sin(theta) + 0.006;  
  12. }  
  13.   
  14. void bd_decrypt(double bd_lat, double bd_lon, double &gg_lat, double &gg_lon)  
  15. {  
  16.     double x = bd_lon - 0.0065, y = bd_lat - 0.006;  
  17.     double z = sqrt(x * x + y * y) - 0.00002 * sin(y * x_pi);  
  18.     double theta = atan2(y, x) - 0.000003 * cos(x * x_pi);  
  19.     gg_lon = z * cos(theta);  
  20.     gg_lat = z * sin(theta);  
  21. }  

火星坐标系(GCJ-02)与百度坐标系(BD-09)转换

标签:

原文地址:http://www.cnblogs.com/yu0806/p/4543980.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!