public static double pi = 3.141592653589793 * 3000.0 / 180.0; /** * 火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换算法 将 GCJ-02 坐标转换成 BD-09 坐标 * * @param gg_lat * @param gg_lon * @return */ public static Gps gcj02_To_Bd09(double gg_lon, double gg_lat) { double x = gg_lon, y = gg_lat; double z = Math.Sqrt(x * x + y * y) + 0.00002 * Math.Sin(y * pi); double theta = Math.Atan2(y, x) + 0.000003 * Math.Cos(x * pi); double bd_lon = z * Math.Cos(theta) + 0.0065; double bd_lat = z * Math.Sin(theta) + 0.006; return new Gps(bd_lon, bd_lat); } /** * 火星坐标系(腾讯地图 谷歌地图) (GCJ-02) 与百度坐标系 (BD-09) 的转换算法 将 BD-09 坐标转换成GCJ-02 坐标 * * @param bd_lon * @param bd_lat * @return */ public static Gps bd09_To_Gcj02(double bd_lon, double bd_lat) { double x = bd_lon - 0.0065, y = bd_lat - 0.006; double z = Math.Sqrt(x * x + y * y) - 0.00002 * Math.Sin(y * pi); double theta = Math.Atan2(y, x) - 0.000003 * Math.Cos(x * pi); double gg_lon = z * Math.Cos(theta); double gg_lat = z * Math.Sin(theta); return new Gps(gg_lon, gg_lat); } //Gps类 public class Gps { public double lat;//纬度 public double lon;//经度 public Gps(double lon, double lat) { this.lat = lat; this.lon = lon; } } public bool IsReusable { get { return false; } }
百度地图 百度坐标 (BD-09)
腾讯地图 火星坐标(GCJ-02)
高德地图 火星坐标(GCJ-02)
谷歌地图(中国) 火星坐标(GCJ-02)
搜狐搜狗地图 搜狗坐标(GCJ-02)
经测试误差还是有的但是影响不大。
本来之前想调用腾讯地图的api 但是不知名什么原因找不到translate方法
var lalg =new qq.maps.convertor.translate(new qq.maps.LatLng(lat, lng), 3, function (res) { latlng = res[0]; console.log("lat:"+latlng.lat) console.log("lng:"+latlng.lng) })
时间: 2024-10-11 23:12:51