之前公司定位用的是百度定位蹲诀,但是由于公司地圖展示位天地圖斑粱,由于偏移嚴(yán)重(畢竟坐標(biāo)系不同)需要坐標(biāo)系轉(zhuǎn)換,之前看公司的處理邏輯是聯(lián)網(wǎng)糾偏(非公司內(nèi)部服務(wù))脯爪,一直也能延用则北,近期由于外網(wǎng)服務(wù)不能使用服務(wù)遷至阿里矿微,無法使用,所以需要另謀方式 尚揣,功夫不負(fù)有心人總算找到 上源碼(親測準(zhǔn)確)
package wewell.com.qcl.util;
public class CoordinateUtil {
private static double x_pi = 3.14159265358979324 * 3000.0 / 180.0;
//pai
private static double pi = 3.1415926535897932384626;
//離心率
private static double ee = 0.00669342162296594323;
//長半軸
private static double a = 6378245.0;
//百度轉(zhuǎn)國測局
public static double[] bd09togcj02(double bd_lon, double bd_lat) {
double x = bd_lon - 0.0065;
double y = bd_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);
double gg_lng = z * Math.cos(theta);
double gg_lat = z * Math.sin(theta);
return new double[] { gg_lng, gg_lat };
}
//國測局轉(zhuǎn)百度
public static double[] gcj02tobd09(double lng, double lat) {
double z = Math.sqrt(lng * lng + lat * lat) + 0.00002 * Math.sin(lat * x_pi);
double theta = Math.atan2(lat, lng) + 0.000003 * Math.cos(lng * x_pi);
double bd_lng = z * Math.cos(theta) + 0.0065;
double bd_lat = z * Math.sin(theta) + 0.006;
return new double[] { bd_lng, bd_lat };
}
//國測局轉(zhuǎn)84
public static double[] gcj02towgs84(double lng, double lat) {
double dlat = transformlat(lng - 105.0, lat - 35.0);
double dlng = transformlng(lng - 105.0, lat - 35.0);
double radlat = lat / 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);
dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * pi);
double mglat = lat + dlat;
double mglng = lng + dlng;
return new double[] { lng * 2 - mglng, lat * 2 - mglat };
}
//經(jīng)度轉(zhuǎn)換
public static double transformlat(double lng, double lat) {
double 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;
}
//緯度轉(zhuǎn)換
public static double transformlng(double lng, double lat) {
double ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * 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(lng * pi) + 40.0 * Math.sin(lng / 3.0 * pi)) * 2.0 / 3.0;
ret += (150.0 * Math.sin(lng / 12.0 * pi) + 300.0 * Math.sin(lng / 30.0 * pi)) * 2.0 / 3.0;
return ret;
}
}
//1 使用說明 (bd09->wgs84 )
public static String getWgs84xy(double x, double y){
//先轉(zhuǎn) 國測局坐標(biāo)
double[] doubles_gcj = CoordinateUtil.bd09togcj02(x, y);//(x 117. y 36. )
//國測局坐標(biāo)轉(zhuǎn)wgs84
double[] doubles_wgs84 = CoordinateUtil.gcj02towgs84(doubles_gcj[0], doubles_gcj[1]);
//返回 糾偏后 坐標(biāo)
return doubles_wgs84[0] + "," + doubles_wgs84[1];
}
//此算法如果不準(zhǔn)涌矢,請聯(lián)系我,我有其他的
//哦快骗,誤差一米內(nèi)蒿辙,只不過需要收費(fèi)