1. 程式人生 > >百度、高德、Googe經緯度轉換

百度、高德、Googe經緯度轉換

	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);
	}
如果哪位大神有更好的糾偏方法,可以拿出來讓大家共同驗證一下