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

百度地图转腾讯地图腾讯地图转百度地图(还有方法二就是使用百度地图api 转火星坐标)-LMLPHP

05-11 13:42