public static double DistanceOfTwoPoints(double lng1,double lat1, double lng2, double lat2) { double radLat1 = Rad(lat1); double radLat2 = Rad(lat2); double a = radLat1 - radLat2; double b = Rad(lng1) - Rad(lng2); double s = 2 * Math.Asin(Math.Sqrt(Math.Pow(Math.Sin(a / 2), 2) + Math.Cos(radLat1) * Math.Cos(radLat2) * Math.Pow(Math.Sin(b / 2), 2))); s = s * 6378137.0 ;//默认为WGS84的参考椭球长轴 s = Math.Round(s * 10000) / 10000; return s; } private static double Rad(double d) { return d * Math.PI / 180.0; }
GaussSphere 为自定义枚举类型 /// <summary> /// 高斯投影中所选用的参考椭球 /// </summary> public enum GaussSphere { Beijing54, Xian80, WGS84, }