浏览代码

fix: GCJ02ToWGS84 accuracy

tags/3.0.0
Disappear520 2 年前
父节点
当前提交
ca0ced379d
没有帐户链接到提交者的电子邮件
共有 1 个文件被更改,包括 12 次插入4 次删除
  1. 12
    4
      modules/transform/CoordTransform.js

+ 12
- 4
modules/transform/CoordTransform.js 查看文件

@@ -73,10 +73,18 @@ class CoordTransform {
if (this.out_of_china(lng, lat)) {
return [lng, lat]
} else {
let d = this.delta(lng, lat)
let mgLng = lng + d[0]
let mgLat = lat + d[1]
return [lng * 2 - mgLng, lat * 2 - mgLat]
let out = [lng, lat]

let gcj02_point = this.WGS84ToGCJ02(lng, lat)
let dlng = gcj02_point[0] - lng
let dlat = gcj02_point[1] - lat
do {
gcj02_point = this.WGS84ToGCJ02((out[0] -= dlng), (out[1] -= dlat))
dlng = gcj02_point[0] - lng
dlat = gcj02_point[1] - lat
} while (Math.abs(dlng) > 1e-7 || Math.abs(dlat) > 1e-7)

return out
}
}


正在加载...
取消
保存