+
liuyg
2022-03-22 1254791f19cf3a1ff70e4ce7c2c41934f5c70115
+
1 files modified
84 ■■■■■ changed files
src/components/mapOncePoint/chousePoint.vue 84 ●●●●● patch | view | raw | blame | history
src/components/mapOncePoint/chousePoint.vue
@@ -33,7 +33,14 @@
        //   this.chousePointData[1] &&
        //   this.chousePointData[2]
        // ) {
        this.$emit("setData", this.chousePointData);
        let outInt = this.gcj02towgs84(
          this.chousePointData[0],
          this.chousePointData[1]
        );
        let outdata = [...outInt, this.chousePointData[2]];
        console.log(this.chousePointData, "gcj02");
        console.log(outdata, " wgs84");
        this.$emit("setData", outdata);
        // } else {
        //   this.$message.error("未成功选择地点");
        //   this.$emit("setData", ["", "", ""]);
@@ -45,7 +52,80 @@
  },
  methods: {
    openMaps(data) {
      this.chousePointData = [data.jd, data.wd, data.name];
      //转wgs84
      let ints = this.wgs84togcj02(data.jd, data.wd);
      this.chousePointData = [...ints, data.name];
    },
    wgs84togcj02(lng, lat) {
      var lat = +lat;
      var lng = +lng;
      if (this.out_of_china(lng, lat)) {
        return [lng, lat];
      } else {
        var dlat = this.transformlat(lng - 105.0, lat - 35.0);
        var dlng = this.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 转换为 WGS84
    gcj02towgs84(lng, lat) {
      var lat = +lat;
      var lng = +lng;
      // 判断是否在国内,不在国内则不做偏移
      if (this.out_of_china(lng, lat)) {
        return [lng, lat];
      } else {
        var dlat = this.transformlat(lng - 105.0, lat - 35.0);
        var dlng = this.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 [lng * 2 - mglng, lat * 2 - mglat];
      }
    },
    out_of_china(lng, lat) {
      var lat = +lat;
      var lng = +lng;
      // 纬度3.86~53.55,经度73.66~135.05
      return !(lng > 73.66 && lng < 135.05 && lat > 3.86 && lat < 53.55);
    },
    transformlat(lng, lat) {
      var lat = +lat;
      var lng = +lng;
      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;
    },
  },
};