zoukankan      html  css  js  c++  java
  • 百度地图转腾讯地图腾讯地图转百度地图(还有方法二就是使用百度地图api 转火星坐标)

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

  • 相关阅读:
    ans_rproxy 说明
    ubuntu adduser
    linux 修改 elf 文件的dynamic linker 和 rpath
    What Is The Promiscuous Mode
    gpart 分区工具
    TortoiseSVN的基本使用方法
    svn和git的区别及适用场景
    TortoiseSVN 和 VisualSVN Server 使用教程
    SVN中trunk、branches、tag的使用
    C/C++中substr函数的应用(简单讲解)
  • 原文地址:https://www.cnblogs.com/chongyao/p/7027655.html
Copyright © 2011-2022 走看看