GIS measure 測距公式和C#,JavaScript的實現)

來源:互聯網
上載者:User

單位:m

Util.distanceByLnglat = function(lng1,lat1,lng2,lat2)
{
    var radLat1 = Util.Rad(lat1);
    var radLat2 = Util.Rad(lat2);
    var a = radLat1 - radLat2;
    var b = Util.Rad(lng1) - Util.Rad(lng2);
    var 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;
    s = Math.round(s * 10000) / 10000;
    return s;
}

Util.Rad = function(d)
{
    return d * Math.PI / 180.0;
}

note
Math.sqrt(x)    :X的平方根
Math.pow(x, n)    :返回x的n次方的數值
Math.cos(x)    :X的餘弦函數
Math.sin(x)    :X的正弦函數
Math.asin(y)    :X的反正弦函數
Math.round(x)    :取最接近整數x的數值
6378137        :長半徑

座標系
WGS—84世界大地座標系(Wor1d Geodetic System)。屬於地心座標系

從Google Map上弄來的根據經緯度求地球表面兩點間距離的實現, 稍微改編了一下,對於我國境內空間距離計算,該實現已經夠用,以米為單位。.Net2.0,C#實現。

       public static double DistanceOfTwoPoints(double lng1,double lat1,  double lng2, double lat2, GaussSphere gs)
        {          
            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))); 字串8
            s = s * (gs == GaussSphere.WGS84 ? 6378137.0 : (gs == GaussSphere.Xian80 ? 6378140.0 : 6378245.0));
            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,
    }

Shenzhen Universiade - Shenzhen 2011 Summer Universiade

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.