在选择地图的地图,有影像图和街道图,影像图选择的是Google
的影像图,街道图也是选择的Google
的,因为下载快。当然国内的高德也是可以的。但是高德和Google
的街道图都有一个问题,和OpenStreetMap
的街道图对比,明显高德、Google
的地图偏移了。
原因:
WGS84
:表示GPS获取的坐标。
GCJ02
:又称火星坐标系,是由中国国家测绘局制定的地理坐标系统,是由WGS84
加密后得到的坐标系。
BD09
:为百度坐标系,在GCJ02
坐标系基础上再次加密。其中bd09ll
表示百度经纬度坐标,bd09mc
表示百度墨卡托米制坐标。
所以我们需要将GPS坐标转化为GCJ-02。
参考资料:
GCJ-02火星坐标系
使用github
中 eviltransform
代码:
var srcCoords = geom.getCoordinates();
for (var j = 0; j < srcCoords.length; j++) {
var coods = srcCoords[j];
if($.isArray(coods)) {
if($.isArray(coods[0])) {
//Plogon
for(var k = 0; k < coods.length; k++){
var subPoint = coods[k];
for(var l = 0; l < subPoint.length; l++){
if(l % 2 != 0) continue;
var lat = subPoint[l + 1], lng = subPoint[l];
var wgs = wgs2gcj(lat, lng);
subPoint[l] = wgs.lng;
subPoint[l+1] = wgs.lat;
}
}
} else {
//LineString
for(var k = 0; k < coods.length; k++){
if(k % 2 != 0) continue;
var lat = coods[k + 1], lng = coods[k];
var wgs = wgs2gcj(lat, lng);
coods[k] = wgs.lng;
coods[k+1] = wgs.lat;
}
}
} else {
//Point
if(j % 2 != 0) continue;
var lat = srcCoords[j + 1], lng = srcCoords[j];
var wgs = wgs2gcj(lat, lng);
srcCoords[j] = wgs.lng;
srcCoords[j+1] = wgs.lat;
}
}
geom.setCoordinates(srcCoords, geom.getLayout());