C# Gmap 根据提供的经度和纬度、以及半径,取得此半径内的最大最小经纬度

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_27278957/article/details/88788688

简述

因项目需求,所以做此功能。在网上查询了很多文章,最终调试成功一种方式:

//描述:根据提供的经度和纬度、以及半径,取得此半径内的最大最小经纬度
//lat:纬度 	lon:经度	raidus:半径(米)
public static double[] GetAround(double lat, double lon, int raidus)
{
	Double latitude = lat;
	Double longitude = lon;

	Double degree = (24901 * 1609) / 360.0;
	double raidusMile = raidus;

	Double dpmLat = 1 / degree;
	Double radiusLat = dpmLat * raidusMile;
	Double minLat = latitude - radiusLat;
	Double maxLat = latitude + radiusLat;

	Double mpdLng = degree * Math.Cos(latitude * (PI / 180));
	Double dpmLng = 1 / mpdLng;
	Double radiusLng = dpmLng * raidusMile;
	Double minLng = longitude - radiusLng;
	Double maxLng = longitude + radiusLng;
	return new double[] { minLat, minLng, maxLat, maxLng };
}

这里提供一篇其他关于此功能的博客:

链接

猜你喜欢

转载自blog.csdn.net/qq_27278957/article/details/88788688