首页 > 学院 > 开发设计 > 正文

地图上计算两点之间的距离

2019-11-10 20:53:10
字体:
来源:转载
供稿:网友
参数是经纬度,C#版: 千米PRivate const double EARTH_RADIUS = 6378.137;//地球半径private static double rad(double d){   return d * Math.PI / 180.0;} public static double GetDistance(double lat1,double lng1,double lat2,double lng2){   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 * EARTH_RADIUS;   s = Math.Round(s * 10000) / 10000;   return s;}java2版:(千米)//private static double EARTH_RADIUS = 6378137.0;(米)private static double EARTH_RADIUS = 6378.137;       private static double rad(double d) {         return d * Math.PI / 180.0;     }         /**     * 根据两个位置的经纬度,来计算两地的距离(单位为KM)     * 参数为String类型     * @param lat1 用户经度     * @param lng1 用户纬度     * @param lat2 商家经度     * @param lng2 商家纬度     * @return     */    public static String getDistance(String lat1Str, String lng1Str, String lat2Str, String lng2Str) {        Double lat1 = Double.parseDouble(lat1Str);        Double lng1 = Double.parseDouble(lng1Str);        Double lat2 = Double.parseDouble(lat2Str);        Double lng2 = Double.parseDouble(lng2Str);                 double radLat1 = rad(lat1);        double radLat2 = rad(lat2);        double difference = radLat1 - radLat2;        double mdifference = rad(lng1) - rad(lng2);        double distance = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(difference / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2)              * Math.pow(Math.sin(mdifference / 2), 2)));        distance = distance * EARTH_RADIUS;        distance = Math.round(distance * 10000) / 10000;        String distanceStr = distance+"";        distanceStr = distanceStr.substring(0, distanceStr.indexOf("."));                 return distanceStr;    }
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表