zoukankan      html  css  js  c++  java
  • 根据经纬度和半径计算经纬度范围

        public class LatLonUtil
        {
            private static double PI = 3.14159265;
            private static double EARTH_RADIUS = 6378137;
            private static double RAD = Math.PI / 180.0;
    
            /// <summary>
            /// 根据提供的经度和纬度、以及半径,取得此半径内的最大最小经纬度
            /// </summary>
            /// <param name="lat">纬度</param>
            /// <param name="lon">经度</param>
            /// <param name="raidus">半径(米)</param>
            /// <returns></returns>
            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 };
            }
    
            /// <summary>
            /// 根据提供的两个经纬度计算距离(米)
            /// </summary>
            /// <param name="lng1">经度1</param>
            /// <param name="lat1">纬度1</param>
            /// <param name="lng2">经度2</param>
            /// <param name="lat2">纬度2</param>
            /// <returns></returns>
            public static double GetDistance(double lng1, double lat1, double lng2, double lat2)
            {
                double radLat1 = lat1 * RAD;
                double radLat2 = lat2 * RAD;
                double a = radLat1 - radLat2;
                double b = (lng1 - lng2) * RAD;
                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;
            }
        }
  • 相关阅读:
    信息安全[0836]
    05 二极管的微变等效和稳压二极管
    04 二极管的直流等效通路
    STM32 ADS112C04
    03 PN与二极管的特性
    STM32中的程序在RAM还是FLASH里运行?
    基于STM32的MLX90614人体红外测温枪
    KEIL5如何打开KEIL4工程 [复制链接]
    02 PN结的形成
    PreparedStatement和Statament的性能
  • 原文地址:https://www.cnblogs.com/xinzheng/p/5667364.html
Copyright © 2011-2022 走看看