首页 > 代码库 > 百度经纬度和google经纬度互转
百度经纬度和google经纬度互转
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | private const double x_pi = 3.14159265358979324 * 3000.0 / 180.0; /// <summary> /// 中国正常坐标系GCJ02协议的坐标,转到 百度地图对应的 BD09 协议坐标 /// </summary> /// <param name="lat">维度</param> /// <param name="lng">经度</param> public static void Convert_GCJ02_To_BD09( ref double lat, ref double lng) { double x = lng, y = lat; double z =Math.Sqrt(x * x + y * y) + 0.00002 * Math.Sin(y * x_pi); double theta = Math.Atan2(y, x) + 0.000003 * Math.Cos(x * x_pi); lng = z * Math.Cos(theta) + 0.0065; lat = z * Math.Sin(theta) + 0.006; } /// <summary> /// 百度地图对应的 BD09 协议坐标,转到 中国正常坐标系GCJ02协议的坐标 /// </summary> /// <param name="lat">维度</param> /// <param name="lng">经度</param> public static void Convert_BD09_To_GCJ02( ref double lat, ref double lng) { double x = lng - 0.0065, y = lat - 0.006; double z = Math.Sqrt(x * x + y * y) - 0.00002 * Math.Sin(y * x_pi); double theta = Math.Atan2(y, x) - 0.000003 * Math.Cos(x * x_pi); lng = z * Math.Cos(theta); lat = z * Math.Sin(theta); } |
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。