• vue 百度BD09加密经纬度转国测局GCJ02经纬度


    vue 百度BD09加密经纬度转国测局GCJ02经纬度

    参考资料:https://blog.csdn.net/hitler_yuzhan/article/details/85237148

    	  // GCJ-02 to BD-09
          bd_encrypta(gg_lon, gg_lat) {
            var X_PI = Math.PI * 3000.0 / 180.0;
            var x = gg_lon, y = gg_lat;
            var z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * X_PI);
            var theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * X_PI);
            var bd_lon = z * Math.cos(theta) + 0.0065;
            var bd_lat = z * Math.sin(theta) + 0.006;
            return [bd_lon, bd_lat]
          },
          
          // BD-09 to GCJ-02
          bMapTransWXMap(lng, lat) {
            let x_pi = 3.14159265358979324 * 3000.0 / 180.0;
            let x = lng - 0.0065;
            let y = lat - 0.006;
            let z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);
            let theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);
            let lngs = z * Math.cos(theta);
            let lats = z * Math.sin(theta);
            return [lngs, lats]
          },
    

    还有其他的转换:
    看一下,有的是Java的,但是计算原理是一样的。转换肯定是误差的,就是看误差的大小了。
    https://www.cnblogs.com/ilimengyang/p/9570389.html
    https://blog.csdn.net/weixin_34356310/article/details/93012277
    https://www.cnblogs.com/zhuyf0506/archive/2004/01/13/6773928.html

    还有一个,直接是一个js文件,wgs84_to_gcj02.js

    //wgs84_to_gcj02.js文件
     
    //地标 转 国测 常量
    var x_PI = (3.14159265358979324 * 3000.0) / 180.0;
    var PI = 3.1415926535897932384626;
    var a = 6378245.0; //卫星椭球坐标投影到平面地图坐标系的投影因子。  
    var ee = 0.00669342162296594323; //椭球的偏心率。
     
     
    //判断是否在国内,在中国国内的经纬度才需要做偏移
    function out_of_china(lng, lat) {
        return (
            lng < 72.004 ||
            lng > 137.8347 ||
            (lat < 0.8293 || lat > 55.8271 || false)
        );
    }
     
    //转化经度
    function transformlng(lng, lat) {
        var ret =
            300.0 +
            lng +
            2.0 * lat +
            0.1 * lng * lng +
            0.1 * lng * lat +
            0.1 * Math.sqrt(Math.abs(lng));
        ret +=
            ((20.0 * Math.sin(6.0 * lng * PI) +
                20.0 * Math.sin(2.0 * lng * PI)) *
                2.0) /
            3.0;
        ret +=
            ((20.0 * Math.sin(lng * PI) +
                40.0 * Math.sin((lng / 3.0) * PI)) *
                2.0) /
            3.0;
        ret +=
            ((150.0 * Math.sin((lng / 12.0) * PI) +
                300.0 * Math.sin((lng / 30.0) * PI)) *
                2.0) /
            3.0;
        return ret;
    }
     
    //转化纬度
    function transformlat(lng, lat) {
        var ret =
            -100.0 +
            2.0 * lng +
            3.0 * lat +
            0.2 * lat * lat +
            0.1 * lng * lat +
            0.2 * Math.sqrt(Math.abs(lng));
        ret +=
            ((20.0 * Math.sin(6.0 * lng * PI) +
                20.0 * Math.sin(2.0 * lng * PI)) *
                2.0) /
            3.0;
        ret +=
            ((20.0 * Math.sin(lat * PI) +
                40.0 * Math.sin((lat / 3.0) * PI)) *
                2.0) /
            3.0;
        ret +=
            ((160.0 * Math.sin((lat / 12.0) * PI) +
                320 * Math.sin((lat * PI) / 30.0)) *
                2.0) /
            3.0;
        return ret;
    }
     
    //wgs84 to gcj02   地球坐标系 转 火星坐标系
    export function wgs84_to_gcj02(lng, lat) {
        if (out_of_china(lng, lat)) {
            return [lng, lat];
        } else {
            var dlat = transformlat(lng - 105.0, lat - 35.0);
            var dlng = transformlng(lng - 105.0, lat - 35.0);
            var radlat = (lat / 180.0) * PI;
            var magic = Math.sin(radlat);
            magic = 1 - ee * magic * magic;
            var sqrtmagic = Math.sqrt(magic);
            dlat =
                (dlat * 180.0) /
                (((a * (1 - ee)) / (magic * sqrtmagic)) * PI);
            dlng =
                (dlng * 180.0) / ((a / sqrtmagic) * Math.cos(radlat) * PI);
            var mglat = lat + dlat;
            var mglng = lng + dlng;
     
            return [mglng, mglat];
        }
    }
     
     
    //gcj02 to wgs84  火星坐标系 转 地球坐标系
    export function gcj02_to_wgs84(lng, lat) {
        if (out_of_china(lng, lat)) {
            return [lng, lat]
        }
        else {
            var dlat = transformlat(lng - 105.0, lat - 35.0);
            var dlng = transformlng(lng - 105.0, lat - 35.0);
            var radlat = lat / 180.0 * PI;
            var magic = Math.sin(radlat);
            magic = 1 - ee * magic * magic;
            var sqrtmagic = Math.sqrt(magic);
            dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * PI);
            dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * PI);
            mglat = lat + dlat;
            mglng = lng + dlng;
            return [lng * 2 - mglng, lat * 2 - mglat]
        }
    }
    

    再需要的组件引用这个js文件。

    import {wgs84_to_gcj02} from "./wgs84_to_gcj02";
    

    使用

    let c = wgs84_to_gcj02(parseFloat(this.tableData[i].longtitude), parseFloat(this.tableData[i].latitude));
    

    可以了,希望对你们有帮助。

  • 相关阅读:
    modf()函数
    面向对象编程五大原则
    .Net网络资源
    整理CentOS常用命令
    在RHEL5上安装oracle10gLinux
    strchr()函数
    swab函数
    Strstr()函数
    tmpnam函数
    strdup ()函数
  • 原文地址:https://www.cnblogs.com/wjw1014/p/14034074.html
Copyright © 2020-2023  润新知