2013-05-27 42 views
1

我提供了一個屬於空間參考GCJ-02的LatLng。 當然,它不能正確顯示在谷歌地圖,因爲我相信,糾正我,如果我錯了,谷歌地圖使用WGS-84。Android谷歌地圖空間座標:從GCJ-02

谷歌地圖服務V2爲Android提供了一種方式來顯示或轉換GCJ-02?

是我使用地理工具的唯一選擇嗎?我不想爲空間轉換引入這麼龐大的圖書館。

感謝您的幫助, 千電子伏

回答

1

圍繞這個問題是問時間,GCJ-之間進行轉換的唯一途徑02和WGS-84將使用基於從data set of Google China and satellite imagery coordinates迴歸的座標的插值方法。 GitHub上有一個Objective-C庫,位於https://github.com/maxime/ChinaMapDeviation

但是,自問題提出以來,GCJ-02加密代碼被泄露,可以在網上很多地方找到,最流行的是the EvilTransform repo

進一步閱讀:

0
public static LatLng wgs_gcj_encrypts(double wgLat, double wgLon) { 
    LatLng point; 
    if (outOfChina(wgLat, wgLon)) { 
     Log.e("Baidu", "outOfChina"); 

     point = new LatLng(wgLat,wgLon); 
     return point; 
    } 
    double dLat = transformLat(wgLon - 105.0, wgLat - 35.0); 
    double dLon = transformLon(wgLon - 105.0, wgLat - 35.0); 
    double radLat = wgLat/180.0 * pi; 
    double magic = Math.sin(radLat); 
    magic = 1 - ee * magic * magic; 
    double sqrtMagic = Math.sqrt(magic); 
    dLat = (dLat * 180.0)/((a * (1 - ee))/(magic * sqrtMagic) * pi); 
    dLon = (dLon * 180.0)/(a/sqrtMagic * Math.cos(radLat) * pi); 
    double lat = wgLat + dLat; 
    double lon = wgLon + dLon; 
    point = new LatLng(lat,lon); 
    return point; 
} 


private static boolean outOfChina(double lat, double lon) { 
    if (lon < 72.004 || lon > 137.8347) 
     return true; 
    if (lat < 0.8293 || lat > 55.8271) 
     return true; 
    return false; 
} 

public static double transformLat(double x, double y) { 
    double ret = -100.0 + 2.0 * x + 3.0 * y + 0.2 * y * y + 0.1 * x * y + 0.2 * Math.sqrt(Math.abs(x)); 
    ret += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0/3.0; 
    ret += (20.0 * Math.sin(y * pi) + 40.0 * Math.sin(y/3.0 * pi)) * 2.0/3.0; 
    ret += (160.0 * Math.sin(y/12.0 * pi) + 320 * Math.sin(y * pi/30.0)) * 2.0/3.0; 
    return ret; 
} 

public static double transformLon(double x, double y) { 
    double ret = 300.0 + x + 2.0 * y + 0.1 * x * x + 0.1 * x * y + 0.1 * Math.sqrt(Math.abs(x)); 
    ret += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0/3.0; 
    ret += (20.0 * Math.sin(x * pi) + 40.0 * Math.sin(x/3.0 * pi)) * 2.0/3.0; 
    ret += (150.0 * Math.sin(x/12.0 * pi) + 300.0 * Math.sin(x/30.0 * pi)) * 2.0/3.0; 
    return ret; 
}