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

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

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

通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離

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

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



同緯度計(jì)算比較簡單

A(60,30),B(60,90)兩點(diǎn)之間,此段代碼和我用余弦定理算出來的結(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,每一度一秒在赤道上的長度計(jì)算如下:

  40075.04km/360°=111.31955km

  111.31955km/60=1.8553258km=1855.3m

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

  任意兩點(diǎn)距離計(jì)算公式為

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

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


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

評(píng)論

# re: 通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離  回復(fù)  更多評(píng)論   

公式不準(zhǔn)
2008-07-10 09:51 | Mr.Fan

# re: 通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離  回復(fù)  更多評(píng)論   

沒對(duì)
2008-08-05 21:42 |

# re: 通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離  回復(fù)  更多評(píng)論   

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

# re: 通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離  回復(fù)  更多評(píng)論   

沒有參考價(jià)值
2009-08-27 15:28 | guoke

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

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: 通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離  回復(fù)  更多評(píng)論   

請(qǐng)問返回的是千米嗎?
2011-08-17 12:02 | 香香

# re: 通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離  回復(fù)  更多評(píng)論   

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

# re: 通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離  回復(fù)  更多評(píng)論   

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

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

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

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

@香香


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

# re: 通過兩個(gè)點(diǎn)的經(jīng)緯度計(jì)算距離  回復(fù)  更多評(píng)論   

你好 ,我看過可以用兩個(gè)標(biāo)志物計(jì)算經(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>
            亚洲欧美日韩一区| 亚洲作爱视频| 欧美激情一区二区久久久| 香蕉成人伊视频在线观看| 欧美福利视频网站| 亚欧成人在线| 欧美刺激午夜性久久久久久久| 免费不卡在线观看| 欧美黄在线观看| 91久久夜色精品国产网站| 欧美亚洲免费高清在线观看| 亚洲欧美成人一区二区在线电影| **性色生活片久久毛片| 久久躁日日躁aaaaxxxx| 亚洲国产一二三| 一区二区三区精品视频| 国产精品视频精品| 亚洲欧美日韩在线高清直播| 久久国产精品一区二区| 在线观看的日韩av| 欧美精品1区| 亚洲欧美日韩一区二区三区在线 | 免费国产一区二区| 亚洲国产老妈| 欧美一区二区三区在线观看视频| 国产区日韩欧美| 另类酷文…触手系列精品集v1小说| 亚洲韩日在线| 久久欧美肥婆一二区| 99精品国产在热久久| 国产一区二区三区四区三区四 | 一区二区电影免费在线观看| 亚洲人成绝费网站色www| 欧美日韩高清在线观看| 久久久久网站| 欧美区视频在线观看| 性刺激综合网| 久久久久国产一区二区| 午夜一区在线| 亚洲特级毛片| 亚洲欧美日韩国产成人精品影院| 亚洲激情自拍| 日韩网站在线观看| 亚洲黑丝在线| 日韩视频一区二区| 国产精品99久久久久久白浆小说| 日韩午夜免费视频| 99精品国产福利在线观看免费| 亚洲日本成人网| 亚洲天堂免费观看| 午夜精品国产| 裸体素人女欧美日韩| 欧美激情国产高清| 99精品欧美一区二区三区综合在线| 亚洲一区二区三区在线观看视频 | 国产日韩欧美精品一区| 久久综合给合| 久久精品水蜜桃av综合天堂| 亚洲高清av| 欧美国内亚洲| 99精品视频一区| 美女主播视频一区| 久久久精品五月天| 麻豆九一精品爱看视频在线观看免费| 亚洲精品日产精品乱码不卡| 亚洲精品影院| 久久精品五月婷婷| 欧美日本免费一区二区三区| 国产精品免费视频xxxx| 91久久黄色| 亚洲综合色激情五月| 美女日韩欧美| 亚洲一区二区三区777| 欧美一区二区三区日韩| 欧美成人a视频| 国产一级精品aaaaa看| 日韩一级免费观看| 免费精品视频| 精品二区视频| 最新高清无码专区| 久久精品综合网| 久久精品噜噜噜成人av农村| 国产农村妇女毛片精品久久莱园子 | 日韩一区二区久久| 欧美日韩在线精品| 亚洲性人人天天夜夜摸| 在线视频亚洲| 国产欧美精品日韩| 久久精品国内一区二区三区| 亚洲欧美国产高清va在线播| 国产精品视频午夜| 久久综合色影院| 欧美成人免费va影院高清| 99re成人精品视频| 亚洲精品在线观看免费| 国产一级揄自揄精品视频| 亚洲黄色一区| 亚洲韩国青草视频| 久久成人羞羞网站| 亚洲一区二区免费在线| 欧美电影免费观看高清| 亚洲一区精彩视频| 一区二区三区欧美| 宅男在线国产精品| 久久免费视频一区| 亚洲图片激情小说| 久久久久久久综合| 国产精品国产成人国产三级| 这里只有精品电影| 欧美日韩国产黄| 最新热久久免费视频| 激情视频一区二区| 久久精品日产第一区二区| 久久人人97超碰国产公开结果| 国产麻豆日韩| 欧美伊人久久久久久久久影院| 亚洲一区三区视频在线观看| 欧美亚州一区二区三区| 欧美一级大片在线免费观看| 一区二区不卡在线视频 午夜欧美不卡'| 在线午夜精品| 麻豆freexxxx性91精品| 日韩小视频在线观看| 葵司免费一区二区三区四区五区| 亚洲视频网站在线观看| 欧美日韩国产在线| 国内自拍一区| 久久综合久久综合九色| 美女成人午夜| 国内精品视频久久| 亚洲激情二区| 欧美精品三级| 亚洲一区在线看| 另类天堂视频在线观看| 午夜精品久久久久久久男人的天堂 | 国产在线一区二区三区四区| 亚洲精品网站在线播放gif| 国产欧美在线视频| 亚洲精品视频在线播放| 一区二区在线视频播放| 亚洲午夜精品网| 在线一区二区三区四区五区| 欧美一区日韩一区| 日韩视频在线免费观看| 一区二区三区四区国产| 亚洲国产精品va在线观看黑人| 久久深夜福利| 亚洲裸体在线观看| 亚洲精品久久嫩草网站秘色| 91久久精品日日躁夜夜躁欧美| 99国内精品| 国产欧美亚洲日本| 久久资源av| 欧美巨乳波霸| 在线一区免费观看| 欧美另类综合| 久久精品女人天堂| 久久精品国产999大香线蕉| 亚洲欧美精品一区| 一区二区三区四区五区精品视频| 欧美二区在线| 亚洲精品在线三区| 亚洲日本国产| 91久久精品www人人做人人爽| aa级大片欧美三级| 麻豆av一区二区三区久久| 欧美激情精品久久久六区热门 | 欧美电影免费观看高清| 欧美一站二站| 国产一区二区三区精品欧美日韩一区二区三区| 欧美成人日本| 亚洲最新在线视频| 久久国产加勒比精品无码| 久久国产乱子精品免费女 | 91久久一区二区| 欧美成va人片在线观看| 久久影院亚洲| 国产精品综合视频| 欧美成人xxx| 欧美成人精品h版在线观看| 精品成人一区二区三区四区| 亚洲一区二区在线免费观看视频| 99国产精品久久久久久久久久| 欧美三日本三级少妇三2023| 欧美在线资源| 午夜精品www| 国产精品久久久久高潮| 久久久av网站| 免费欧美网站| 国产精品a级| 国产在线精品一区二区夜色| 在线看一区二区| 亚洲视频在线观看三级| 久久超碰97人人做人人爱| 欧美成人午夜剧场免费观看| 一本在线高清不卡dvd | 国产日韩欧美精品在线| 最新日韩在线视频| 新67194成人永久网站| 欧美ed2k|