青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Khan's Notebook GCC/GNU/Linux Delphi/Window Java/Anywhere

路漫漫,長修遠,我們不能沒有錢
隨筆 - 173, 文章 - 0, 評論 - 257, 引用 - 0
數(shù)據(jù)加載中……

通過兩個點的經(jīng)緯度計算距離

最近開始做一個類似gis的東西. 需要求一些經(jīng)緯度相關(guān)的值..

看了通過兩個點的經(jīng)緯度計算距離這篇,據(jù)說是Google里扒來的算法,于是決定驗證一下。
通過計算發(fā)現(xiàn)非常正確。
用30,120和31,121兩個坐標點進行驗證,同Mapinfo中計算的結(jié)果非常的相近。
后來又把坐標系直接當(dāng)成直角坐標系來計算,發(fā)現(xiàn)誤差很大。
于是仍然用直角坐標系方法來計算,給緯度加上了個0.86的參數(shù),這樣計算下來和結(jié)果相近。




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;
}


vb代碼

Const EARTH_RADIUS = 6378.137
Const Pi = 3.1415926535898

Function rad(ByVal d As Double) As Double
rad = d * Pi / 180
End Function

Function GetDistance(lat1 As Double, lng1 As Double, lat2 As Double, lng2 As Double) As Double
Dim radlat1 As Double, radlat2 As Double
Dim a As Double, b As Double, s As Double, Temp As Double
radlat1 = rad(lat1)
radlat2 = rad(lat2)
a = radlat1 - radlat2
b = rad(lng1) - rad(lng2)
Temp = Sqr(Sin(a / 2) ^ 2 + Cos(radlat1) * Cos(radlat2) * Sin(b / 2) ^ 2)
s = 2 * Atn(Temp / Sqr(-Temp * Temp + 1))     '沒有反正弦函數(shù),網(wǎng)上找了個
s = s * EARTH_RADIUS
GetDistance = s
End Function

Private Sub Command1_Click()
Text5.Text = Str(GetDistance(Val(Text1.Text), Val(Text2.Text), Val(Text3.Text), Val(Text4.Text)))
End Sub

Private Sub Command2_Click()
Text5.Text = Str((Sqr((Val(Text3.Text) - Val(Text1.Text)) ^ 2 + (Val(Text4.Text) - Val(Text2.Text)) ^ 2)) * 111.3199338)
End Sub

Private Sub Command3_Click()
Text5.Text = Str((Sqr((Val(Text3.Text) * 0.86 - Val(Text1.Text) * 0.86) ^ 2 + (Val(Text4.Text) - Val(Text2.Text)) ^ 2)) * 111.3199338)
End Sub



同緯度計算比較簡單

A(60,30),B(60,90)兩點之間,此段代碼和我用余弦定理算出來的結(jié)果很一致。
余弦定理的步驟是:1、算A、B弦長:地球半徑R*cos(經(jīng)度差60)=R/2;
2、算角AOB,O為地球圓心,利用余弦定理,
cosAOB=(2R*R-(R/2)^2) /2*R*R=7/8;
3、弧AB的長為:R*arc cos(7/8);求畢



原理:

地球赤道上環(huán)繞地球一周走一圈共40075.04公里,而@一圈分成360°,而每1°(度)有60,每一度一秒在赤道上的長度計算如下:

  40075.04km/360°=111.31955km

  111.31955km/60=1.8553258km=1855.3m

  而每一分又有60秒,每一秒就代表1855.3m/60=30.92m

  任意兩點距離計算公式為

  d=111.12cos{1/[sinΦAsinΦB十cosΦAcosΦBcos(λB—λA)]}

  其中A點經(jīng)度,緯度分別為λA和ΦA,B點的經(jīng)度、緯度分別為λB和ΦB,d為距離。


posted on 2008-02-28 15:18 Khan 閱讀(16307) 評論(11)  編輯 收藏 引用 所屬分類: GCC/G++跨平臺開發(fā)Java周邊技術(shù)

評論

# re: 通過兩個點的經(jīng)緯度計算距離  回復(fù)  更多評論   

公式不準
2008-07-10 09:51 | Mr.Fan

# re: 通過兩個點的經(jīng)緯度計算距離  回復(fù)  更多評論   

沒對
2008-08-05 21:42 |

# re: 通過兩個點的經(jīng)緯度計算距離  回復(fù)  更多評論   

公式 d=111.12cos{1/[sinΦA(chǔ)sinΦB十cosΦA(chǔ)cosΦBcos(λB—λA)]} 肯定是錯的:cos 的值在-1 到 1 之間,111.12cos{...} 其絕對值不超過111.12.
這個公式算出的結(jié)果意味著任意兩點之間的距離小于111.12.
2008-09-23 22:58 | huang

# re: 通過兩個點的經(jīng)緯度計算距離  回復(fù)  更多評論   

沒有參考價值
2009-08-27 15:28 | guoke

# re: 通過兩個點的經(jīng)緯度計算距離[未登錄]  回復(fù)  更多評論   

public static void main(String args[]) {
double latA=rad(36.6),lngA=rad(116.4);
double latB=rad(36.7),lngB=rad(116.4);
//double d=111.12*Math.cos(1/(Math.sin(latA)*Math.sin(latB)+Math.cos(latA)*Math.cos(latB)*Math.cos(lngB-lngA)));
double d=2*Math.asin(Math.sqrt(Math.pow(Math.sin((latA-latB)/2), 2)+Math.cos(latA)*Math.cos(latB)*Math.pow(Math.sin((lngA-lngB)/2), 2)))*6378.137;
System.out.println(d);


}

private static double rad(double d){
return d * Math.PI / 180.0;
}
2009-12-18 10:32 | bo

# re: 通過兩個點的經(jīng)緯度計算距離  回復(fù)  更多評論   

請問返回的是千米嗎?
2011-08-17 12:02 | 香香

# re: 通過兩個點的經(jīng)緯度計算距離  回復(fù)  更多評論   

這個是我的QQ 等樓主有空了 能告訴我一下嗎
2011-08-17 12:03 | 香香

# re: 通過兩個點的經(jīng)緯度計算距離  回復(fù)  更多評論   

1608036033
2011-08-17 12:03 | 香香

# re: 通過兩個點的經(jīng)緯度計算距離[未登錄]  回復(fù)  更多評論   

@huang
那個貌似是Asin 吧,怎么可能會只在在-1~1
2011-08-27 16:22 | 1

# re: 通過兩個點的經(jīng)緯度計算距離[未登錄]  回復(fù)  更多評論   

@香香


最后經(jīng)過一個 round 應(yīng)該是千米 吧
2011-08-27 16:23 | 1

# re: 通過兩個點的經(jīng)緯度計算距離  回復(fù)  更多評論   

你好 ,我看過可以用兩個標志物計算經(jīng)緯度的
2011-10-12 23:26 | 洛麗塔
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            在线视频欧美日韩| 玖玖玖免费嫩草在线影院一区| 麻豆av一区二区三区| 久久亚洲综合| 亚洲精品人人| 亚洲视频网站在线观看| 狠狠入ady亚洲精品| 亚洲精选一区二区| 国产日产亚洲精品系列| 欧美高清自拍一区| 国产精品无码永久免费888| 久久视频这里只有精品| 欧美日韩高清在线| 久久久夜色精品亚洲| 欧美激情一区二区三区不卡| 欧美在线观看www| 久久精品综合网| 久久久国产一区二区| 国产精品va在线| 在线视频欧美日韩精品| 最新日韩中文字幕| 欧美激情视频一区二区三区免费| 久久亚洲综合色| 在线免费观看欧美| 欧美成人高清视频| 99视频热这里只有精品免费| 亚洲午夜激情在线| 黄色另类av| 免费国产自线拍一欧美视频| 亚洲国产女人aaa毛片在线| 亚洲国产激情| 欧美精品亚洲| 久久久免费精品视频| 久久国产精品72免费观看| 快she精品国产999| 伊人久久大香线蕉综合热线| 久久成人18免费网站| 久久尤物视频| 亚洲国产日韩欧美| 久久国产一区| 国产精品久久久久久久久免费樱桃| 国产精品久久久久久久久久免费| 欧美成年人在线观看| 国产最新精品精品你懂的| 欧美高清视频一二三区| 国产尤物精品| 亚洲国产影院| 国产亚洲激情视频在线| 久久一区国产| 欧美怡红院视频一区二区三区| 9色国产精品| 午夜一区二区三视频在线观看 | 亚洲少妇最新在线视频| 国内伊人久久久久久网站视频| 亚洲精品之草原avav久久| 亚洲影院免费| 国产精品亚洲不卡a| 制服丝袜亚洲播放| 亚洲视频视频在线| 国产精品久久久99| 最新亚洲一区| 日韩一区二区精品葵司在线| 久久理论片午夜琪琪电影网| 老牛国产精品一区的观看方式| 国内精品久久久久影院 日本资源| 久久精品国产亚洲高清剧情介绍 | 亚洲视频 欧洲视频| 亚洲免费视频中文字幕| 国产精品九九| 亚洲一区二区成人| 欧美影院成年免费版| 国产视频一区在线观看| 性做久久久久久久久| 久久综合给合久久狠狠色| 伊人精品在线| 欧美韩日高清| 夜夜嗨av一区二区三区免费区| 亚洲一区精品电影| 国产欧美日韩亚州综合| 久久久91精品国产一区二区三区| 开元免费观看欧美电视剧网站| 最新国产成人av网站网址麻豆| 欧美日韩性生活视频| 午夜一区在线| 亚洲国产日韩欧美| 亚洲男女毛片无遮挡| 国内精品久久国产| 免费成人av| 一本色道**综合亚洲精品蜜桃冫 | 国产亚洲精品福利| 久久精品国产欧美亚洲人人爽| 欧美激情一区二区三区高清视频| 国产专区精品视频| 亚洲精品黄色| 国产精品99久久久久久久女警 | 亚洲一区二区免费视频| 欧美一区二区三区四区视频| 午夜日本精品| 亚洲高清影视| 午夜亚洲视频| 欧美黄色一区二区| 一区二区在线免费观看| 久久高清福利视频| 欧美v日韩v国产v| 亚洲欧美日韩网| 久久大香伊蕉在人线观看热2| 亚洲综合色自拍一区| 亚洲精品久久久久久久久久久久| 中文av字幕一区| 国产精品欧美久久久久无广告| 国产乱子伦一区二区三区国色天香| 久久精品国产久精国产思思| 你懂的成人av| 午夜在线视频观看日韩17c| 欧美成人精品| 欧美高清视频在线播放| 亚洲一区二区高清| 欧美国产激情| 性亚洲最疯狂xxxx高清| 最新国产成人在线观看| 国产欧美亚洲日本| 国产精品地址| 欧美xxx成人| 亚洲一区二区精品在线观看| 亚洲高清视频一区二区| 久久久国产精品一区二区中文| 一区二区高清在线| 国产专区综合网| 欧美成人午夜免费视在线看片| 欧美一区激情视频在线观看| 狠狠久久婷婷| 亚洲午夜女主播在线直播| 国产欧美日韩视频一区二区三区| 最近中文字幕日韩精品| 欧美1区视频| 欧美体内谢she精2性欧美| 在线日韩欧美| 亚洲高清激情| 国产精品视频久久| 91久久视频| 欧美吻胸吃奶大尺度电影| 久久久久久69| 一本久久综合亚洲鲁鲁五月天| 免费久久精品视频| 欧美日韩久久不卡| 久久一区中文字幕| 久久精品电影| 国产视频在线观看一区二区| 欧美中文字幕久久| 日韩网站在线看片你懂的| 久久99在线观看| 在线观看亚洲一区| 久久久亚洲精品一区二区三区| 欧美影院一区| 国产精品久久综合| 国产精品久久久久久久久久久久久久 | 尤物精品国产第一福利三区| 韩国美女久久| 性欧美video另类hd性玩具| 久久香蕉国产线看观看网| 久久精品91久久久久久再现| 亚洲视频自拍偷拍| 9久re热视频在线精品| 国产精品自在在线| 亚洲一区久久| 99国产精品99久久久久久| 欧美福利一区二区三区| 亚洲国产天堂久久综合网| 久久高清国产| 亚洲国产天堂久久国产91| 亚洲无玛一区| 小嫩嫩精品导航| 亚洲一区三区电影在线观看| 香蕉国产精品偷在线观看不卡| 宅男精品视频| 欧美一级二区| 亚洲一区二区精品视频| 久久久久久久999精品视频| 欧美精品在线免费观看| 国产精品v亚洲精品v日韩精品 | 狠狠色综合网站久久久久久久| 亚洲国产天堂久久国产91| 一区二区三区在线免费视频| 狠狠色综合色区| 亚洲精品日韩激情在线电影| 99re8这里有精品热视频免费| 欧美一区二区三区日韩| 久久久99免费视频| 亚洲精品永久免费精品| 在线亚洲自拍| 噜噜噜噜噜久久久久久91 | 亚洲欧美日韩在线不卡| 欧美va天堂va视频va在线| 日韩天天综合| 亚洲清纯自拍| 久久精品国语| 一二美女精品欧洲| 欧美一区网站| 国产精品超碰97尤物18| 国外视频精品毛片|