首页 > 代码库 > 百度地图转腾讯地图腾讯地图转百度地图

百度地图转腾讯地图腾讯地图转百度地图

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

  

技术分享

 

百度地图转腾讯地图腾讯地图转百度地图