百度、高德、Googe經緯度轉換
阿新 • • 發佈:2019-01-31
如果哪位大神有更好的糾偏方法,可以拿出來讓大家共同驗證一下private static double x_pi = 3.14159265358979324 * 3000.0 / 180.0; /** * 中國正常座標系GCJ02協議的座標,轉到 百度地圖對應的 BD09 協議座標 * * @param lat * @param lng */ public static void Convert_GCJ02_To_BD09(double lat, double lng) { double x = lng, y = lat; double z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi); double theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi); lng = z * Math.cos(theta) + 0.0065; lat = z * Math.sin(theta) + 0.006; } public static double Convert_GCJ02_To_BD09_Lat(double lat, double lng) { double x = lng, y = lat; double z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi); double theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi); lng = z * Math.cos(theta) + 0.0065; lat = z * Math.sin(theta) + 0.006; return lat; } public static double Convert_GCJ02_To_BD09_Lng(double lat, double lng) { double x = lng, y = lat; double z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi); double theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi); lng = z * Math.cos(theta) + 0.0065; lat = z * Math.sin(theta) + 0.006; return lng; } /** * 百度地圖對應的 BD09 協議座標,轉到 中國正常座標系GCJ02協議的座標 * * @param lat * @param lng */ public static void Convert_BD09_To_GCJ02(double lat, double lng) { double x = lng - 0.0065, y = lat - 0.006; double z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi); double theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi); lng = z * Math.cos(theta); lat = z * Math.sin(theta); }