墨卡托与经纬度转换工具

public class CoordinateUtil {

		//经纬度转墨卡托
		public static double[] lonLat2Mercator(double lon,double lat){
			double[] result = new double[2]; 
			double x = lon * 20037508.34 / 180;
			double y = Math.log(Math.tan((90 + lat) * Math.PI / 360)) / (Math.PI / 180);
			y = y * 20037508.34 / 180;
			result[0] = x;
			result[1] = y;
			return result;
		}
		
		//经度转墨卡托
		public static double lon2Mercator(double lon){
			return lon * 20037508.34 / 180;
		}
		
		//纬度转墨卡托
		public static double lat2Mercator(double lat){
			double y = Math.log(Math.tan((90 + lat) * Math.PI / 360)) / (Math.PI / 180);
			return y * 20037508.34 / 180;
		}
		
		//墨卡托转经纬度
		public static double[] Mercator2lonLat(double lon,double lat){
			double[] result = new double[2]; 
			double x = lon / 20037508.34 * 180;
			double y = lat / 20037508.34 * 180;
			y = 180 / Math.PI * (2 * Math.atan(Math.exp(y * Math.PI / 180)) - Math.PI / 2);
			result[0] = x;
			result[1] = y;
			return result;
		}
		
		//墨卡托经度转换
		public static double Mercator2lon(double lon){
			return lon / 20037508.34 * 180;
		}
		
		//墨卡托纬度转换
		public static double Mercator2lat(double lat){
			double y = lat / 20037508.34 * 180;
			return 180 / Math.PI * (2 * Math.atan(Math.exp(y * Math.PI / 180)) - Math.PI / 2);
		}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值