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) })